用javascript動態調整iframe高度
轉載請保留原始鏈接:http://www.zeali.net/blog/entry.php?id=81

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

首先,在你的主頁面上必須包含以下這段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;
    }

    elseif (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>

arrow
arrow
    全站熱搜

    wbkuo 發表在 痞客邦 留言(0) 人氣()