iframe自适应高度的多种方法方法小结
第一种♋方法:代码简【dài mǎ jiǎn】单,兼容性🤣还可以【hái kě yǐ】,大家可【dà jiā kě】👑以先测试下。
function SetWinHeight(obj)
{
var win=obj;
if (document.getElementById)
{
if (win && !window.opera)
{
if (win.contentDocument && win.contentDocument.body.offsetHeight)
win.height = win.contentDocument.body.offsetHeight;
else if(win.Document && win.Document.body.scrollHeight)
win.height = win.Document.body.scrollHeight;
}
}
}
最后🌾,加入【jiā rù】iframe,不能丢掉🧟onload属性,当然了✈,id也必须【yě bì xū】也函数【yě hán shù】中的win匹配
<iframe width="778" align="center" height="200" id="win" name="win" onload="Javascript:SetWinHeight(this)" frameborder="0" scrolling="no" src="1.htm"></iframe>
这么的【zhè me de】这种也🗝是跟上面的解🍵决方法类似的【lèi sì de】代码🍌
经典代码🍌 iFrame 自适应【zì shì yīng】🤾高度🎑,在【zài】IE6/IE7/IE8/Firefox/Opera/Chrome/Safari通过测试【shì】。
HTML代码🍌:
<iframe src="http://zbbingyang.com/" id="iframepage" name="iframepage" frameBorder=0 scrolling=no width="100%" onLoad="iFrameHeight()" ></iframe>Javascript代码【dài mǎ】🤧:
<script type="text/javascript" language="javascript">
function iFrameHeight() {
var ifm= document.getElementById("iframepage");
var subWeb = document.frames ? document.frames["iframepage"].document : ifm.contentDocument;
if(ifm != null && subWeb != null) {
ifm.height = subWeb.body.scrollHeight;
}
}
</script>
下面这个兼容性更好一些
<script language="javascript" type="text/javascript">
function dyniframesize(down) {
var pTar = null;
if (document.getElementById){
pTar = document.getElementById(down);
}
else{
eval('pTar = ' + down + ';');
}
if (pTar && !window.opera){
//begin resizing iframe
pTar.style.display="block"
if (pTar.contentDocument && pTar.contentDocument.body.offsetHeight){
//ns6 syntax
pTar.height = pTar.contentDocument.body.offsetHeight +20;
pTar.width = pTar.contentDocument.body.scrollWidth+20;
}
else if (pTar.Document && pTar.Document.body.scrollHeight){
//ie5+ syntax
pTar.height = pTar.Document.body.scrollHeight;
pTar.width = pTar.Document.body.scrollWidth;
}
}
}
</script>
<iframe src ="/default2.aspx" frameborder="0" marginheight="0" marginwidth="0" frameborder="0" scrolling="auto" id="ifm" name="ifm" onload="javascript:dyniframesize('ifm');" width="100%">
</iframe>
另一种【lìng yī zhǒng】情况的🤦iframe解决方【jiě jué fāng】案(超简单)
重要提🐯示:src=中你必须填写👖的网页地址,一定要🎯和本页🕹面在同【miàn zài tóng】一个站【yī gè zhàn】点上😫,否则,会抱错,说🎪“拒绝访🐽问【wèn】!”(实际上【shí jì shàng】这是因为Js的跨域问题导【wèn tí dǎo】致拒绝访🐽问【wèn】的)
之前自【zhī qián zì】🤤己也碰【jǐ yě pèng】到过这个问题【gè wèn tí】📵,为了得到答案🤜去网上搜索🚊,发现有不少人【bú shǎo rén】也遇到【yě yù dào】了这样【le zhè yàng】的问【wèn】题,现在就把解决方【jiě jué fāng】法共享一下【xiǎng yī xià】🎻
1、建立一💂个bottom.js的文件【de wén jiàn】❓,然后输入下面的代码【de dài mǎ】(只有两行哦【háng ò】)
parent.document.all("框架【kuàng jià】🏞ID名【míng】💐").style.height=document.body.scrollHeight;
parent.document.all("框架【kuàng jià】🏞ID名【míng】💐").style.width=document.body.scrollWidth;
这里的【zhè lǐ de】💰 框架ID名【míng】 就是🥪Iframe的ID,比如:
<IFRAME id="框架【kuàng jià】🕕ID名" name="left" frameBorder=0 scrolling=no src="XXX.asp" width="100%"></IFRAME>
2、给你网站里所【zhàn lǐ suǒ】🙄有的被【yǒu de bèi】👏包含文件里面【jiàn lǐ miàn】每个都💥加入
<script language = "JavaScript" src = "bottom.js"/></script>
3、OK,收工!
在【zài】WINXP、IE6下面测【xià miàn cè】🚙试通过。很简单吧!
实现【shí xiàn】 iframe 的自适【de zì shì】🚉应高度【yīng gāo dù】🆚
实现【shí xiàn】 iframe 的自适【de zì shì】🚉应高度【yīng gāo dù】🆚,能够随着页面的【de】长度自动的【zì dòng de】🔔适应以免除页【miǎn chú yè】面和【miàn hé】 iframe 同时出【tóng shí chū】现滚动条的现【tiáo de xiàn】🍚象【xiàng】。
<script type="text/javascript">
//** iframe自动适【zì dòng shì】😯应页面📽 **//
//输入你希望根据页面🔶高度自动调【dòng diào】🔓整高度的【de】iframe的【de】名称的【de】列表
//用逗号把每个【bǎ měi gè】iframe的【de】ID分隔🤯. 例如【lì rú】⏹: ["myframe1", "myframe2"],可以只有一个【yǒu yī gè】窗体,则不用💝逗号。
//定义【dìng yì】iframe的【de】ID
var iframeids=["test"]
//如果用⛴户的【de】浏🌮览器不【lǎn qì bú】支持【zhī chí】iframe是否将iframe隐藏🎖 yes 表示隐🦑藏,no表示不隐藏🎖
var iframehide="yes"
function dyniframesize()
{
var dyniframe=new Array()
for (i=0; i<iframeids.length; i++)
{
if (document.getElementById)
{
//自动调【dòng diào】🔓整iframe高度
dyniframe[dyniframe.length] = document.getElementById(iframeids);
if (dyniframe && !window.opera)
{
dyniframe.style.display="block"
if (dyniframe.contentDocument && dyniframe.contentDocument.body.offsetHeight) //如果用⛴户的【de】浏🌮览器是【lǎn qì shì】🐤NetScape
dyniframe.height = dyniframe.contentDocument.body.offsetHeight;
else if (dyniframe.Document && dyniframe.Document.body.scrollHeight) //如果用⛴户的【de】浏🌮览器是【lǎn qì shì】🐤IE
dyniframe.height = dyniframe.Document.body.scrollHeight;
}
}
//根据设定的【de】参数来处理不支【lǐ bú zhī】持iframe的【de】浏览🚔器的【de】显💿示问题
if ((document.all || document.getElementById) && iframehide=="no")
{
var tempobj=document.all? document.all[iframeids] : document.getElementById(iframeids)
tempobj.style.display="block"
}
}
}
if (window.addEventListener)
window.addEventListener("load", dyniframesize, false)
else if (window.attachEvent)
window.attachEvent("onload", dyniframesize)
else
window.onload=dyniframesize
</script>
第三中方法批📿量iframe自适应:
工作中【gōng zuò zhōng】🏥遇到🐷iframe随所含⛹内容自🕞适应高度💄的【de】问题🔓,以前在网上看到过类🐌似问题💽的解决【de jiě jué】方💝法,于是搜索一下,找到了【zhǎo dào le】一个比📢较完整🍂的【de】能够兼容浏【jiān róng liú】览器的解决【de jiě jué】方💝法,省得自己写了【jǐ xiě le】。
虽然不用自己写【xiě】,思路还【sī lù hái】是要明【shì yào míng】白,基本上就是取得iframe属性【shǔ xìng】src所指定【suǒ zhǐ dìng】😀的【de】包含文档中内容的【de】高度💄,然后用【rán hòu yòng】来设置【lái shè zhì】🗼iframe自身的【zì shēn de】😀高度💄,在iframe所在页面载入【miàn zǎi rù】🅾时对页🐐面中的【miàn zhōng de】所有需【suǒ yǒu xū】要自适应高度💄的【de】iframe进行自【jìn háng zì】🛹动设置【dòng shè zhì】📌,省时省【shěng shí shěng】🌋力,如果确【rú guǒ què】🍐定页面【dìng yè miàn】中全部【zhōng quán bù】iframe都需要自适应高度💄,直接取⬇得iframe数组给代码💭,就连【jiù lián】ID都不用自己写了【jǐ xiě le】,完成程序搞定。(代码💭贴上来🚩:)
<script language="javascript">
//输入你希望根据页面高度自【gāo dù zì】动调整【zhěng】⚪高度的【gāo dù de】iframe的名称【de míng chēng】的【de】列表
//用逗号【dòu hào】🍌把每个💛iframe的【de】ID分隔. 例如🍑: ["myframe1", "myframe2"],可以只有一个【yǒu yī gè】窗体【chuāng tǐ】,则不用逗号【dòu hào】🍌。
//定义❇iframe的【de】ID
var iframeids=["test"];
//如果用【rú guǒ yòng】户的【de】浏⛳览器不【lǎn qì bú】支持【zhī chí】✔iframe是否将iframe隐藏✡ yes 表示隐藏✡,no表示不【biǎo shì bú】😯隐藏✡
var iframehide="yes";
function dyniframesize()
{
var dyniframe=new Array()
for (i=0; i<iframeids.length; i++)
{
if (document.getElementById)
{
//自动调整【zhěng】⚪iframe高度
dyniframe[dyniframe.length] = document.getElementById(iframeids[i]);
if (dyniframe[i] && !window.opera)
{
dyniframe[i].style.display="block";
if (dyniframe[i].contentDocument && dyniframe[i].contentDocument.body.offsetHeight) //如果用【rú guǒ yòng】户的【de】浏⛳览器是🏖NetScape
关键词:iframe
阅读本文后您有什么感想? 已有 人给出评价!
- 2
- 1
- 1
- 1
- 2
- 1