當(dāng)你在頁面上使用了iframe之后,一般來說會不希望iframe顯示難看的滾動條,以使iframe里面的內(nèi)容和主頁面的內(nèi)容渾然一體。這時候你會設(shè)置 scrolling="no" 屬性。但是這樣一來如果iframe里面的內(nèi)容是變化的,高度會隨之內(nèi)容的變化而變化的時候,你的iframe就會顯得太長導(dǎo)致底下一大片空白,或者正好相反,由于iframe的高度太小導(dǎo)致一部分內(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" width=200 height=100></iframe> |
|