[轉]用javascript動態調整iframe高度

當你在頁面上使用了iframe之後,一般來說會不希望iframe顯示難看的滾動條,以使iframe裏面的內容和主頁面的內容渾然一體。這時候你會設置 scrolling="no" 屬性。但是這樣一來如果iframe裏面的內容是變化的,高度會隨之內容的變化而變化的時候,你的iframe就會顯得太長導致底下一大片空白,或者正好相反,由於iframe的高度太小導致一部分內容會被擋住。這裏我提供一個兼容IE/NS/Firefox的javascript腳本實現動態調整iframe的高度。如果需要調整寬度的話,原理是一樣的,本文不加詳述。

首先,在你的主頁面上必須包含以下這段javascript代碼:

 <script language="Javascript">
//動態調整iframe高度
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="http://www2.zeali.net/myiframesrc.phpwidth="200" height="100"></iframe>

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章