用javascript動態(tài)調(diào)整iframe高度的方法
更新時間:2007年03月06日 00:00:00 作者:
當你在頁面上使用了iframe之后,一般來說會不希望iframe顯示難看的滾動條,以使iframe里面的內(nèi)容和主頁面的內(nèi)容渾然一體。這時候你會設(shè)置 scrolling="no" 屬性。但是這樣一來如果iframe里面的內(nèi)容是變化的,高度會隨之內(nèi)容的變化而變化的時候,你的iframe就會顯得太長導致底下一大片空白,或者正好相反,由于iframe的高度太小導致一部分內(nèi)容會被擋住。這里我提供一個兼容IE/NS/Firefox的javascript腳本實現(xiàn)動態(tài)調(diào)整iframe的高度。如果需要調(diào)整寬度的話,原理是一樣的,本文不加詳述。
首先,在你的主頁面上必須包含以下這段javascript代碼:
<script language="Javascript">
var getFFVersion=navigator.userAgent.substring(navigator.userAgent.indexOf("Firefox")).split("/")[1]
//extra height in px to add to iframe in FireFox 1.0+ browsers
var FFextraHeight=getFFVersion>=0.1? 16 : 0
function dyniframesize(iframename) {
var pTar = null;
if (document.getElementById){
pTar = document.getElementById(iframename);
}
else{
eval('pTar = ' + iframename + ';');
}
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+FFextraHeight;
}
else if (pTar.Document && pTar.Document.body.scrollHeight){
//ie5+ syntax
pTar.height = pTar.Document.body.scrollHeight;
}
}
}
</script>
然后對于主頁面用到iframe的地方添加代碼:
<iframe id="myTestFrameID"
onload="javascript:{dyniframesize('myTestFrameID');}"
marginwidth=0 marginheight=0 frameborder=0
scrolling=no src="/myiframesrc.php"
首先,在你的主頁面上必須包含以下這段javascript代碼:
復制代碼 代碼如下:
<script language="Javascript">
var getFFVersion=navigator.userAgent.substring(navigator.userAgent.indexOf("Firefox")).split("/")[1]
//extra height in px to add to iframe in FireFox 1.0+ browsers
var FFextraHeight=getFFVersion>=0.1? 16 : 0
function dyniframesize(iframename) {
var pTar = null;
if (document.getElementById){
pTar = document.getElementById(iframename);
}
else{
eval('pTar = ' + iframename + ';');
}
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+FFextraHeight;
}
else if (pTar.Document && pTar.Document.body.scrollHeight){
//ie5+ syntax
pTar.height = pTar.Document.body.scrollHeight;
}
}
}
</script>
然后對于主頁面用到iframe的地方添加代碼:
<iframe id="myTestFrameID"
onload="javascript:{dyniframesize('myTestFrameID');}"
marginwidth=0 marginheight=0 frameborder=0
scrolling=no src="/myiframesrc.php"
相關(guān)文章
Javascript中的函數(shù)聲明與函數(shù)表達式(奇技淫巧)
Javascript有很多有趣的用法,在Google Code Search里能找到不少,今天從火丁筆記看到的,非常不錯,推薦大家看下。2011-03-03
uni-app彈出層uni-popup使用及修改默認樣式的方法實例
我們在使用uniapp開發(fā)的時候,有時可以使用uniapp自有的樣式模板,這樣可以提高開發(fā)效率,下面這篇文章主要給大家介紹了關(guān)于uni-app彈出層uni-popup使用及修改默認樣式的相關(guān)資料,需要的朋友可以參考下2022-11-11

