<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 122,  comments - 25,  trackbacks - 0
    1、目的
    系統通過一內嵌頁面(iframe) 來展現網頁內容(也包括內嵌頁中再嵌一個網頁),這將會引起如下幾個問題:
    a.不同的網頁內容多少不一致,導致iframe的高度無法與實現內容或瀏覽器高度相匹配。
    b.窗口縮放時,不能iframe不能進行自動調整。

    針對這兩個問題,寫了一些js方法,使iframe自動適應內容或瀏覽器高度。

    2、js代碼
    在主框回頁面中包括如下js方法:
    /**
     * 內嵌頁面的高度設置
     
    */
    function handleFrameLoad() {
     
    var hDoc = getBodyHeight(document);
     
    var tblmain =  document.getElementById('tblMain');
     
    var mFrame = window.mainFrame;
     
    var hFrameDoc = getFrameHeight(mFrame);
     
    var hTable = hDoc-80; //減去該頁面除iframe外其他控件所占的高度.
     
    if(hFrameDoc > hTable) hTable = hFrameDoc;
     tblmain.style.height 
    = hTable;
     mFrame.height 
    = hTable;
     
    if(window.mainFrame.moduleRight != null){
       
    //表示該內嵌頁,包含內嵌的頁面,頁iframe的id固定為moduleRight。
        initFrameHeight(mFrame,hTable);
     }
    }

    /**
     * 獲取當前頁面的高度
     
    */
    function getBodyHeight(doc){
      
    if(doc.all) return doc.body.offsetHeight;
      
    else return doc.body.scrollHeight;
    }

    /**
     * 獲取內嵌頁中的高度.
     * 若另含子內嵌(
    moduleRight)頁時,應考慮該頁面的高度.
     
    */
    function getFrameHeight(mFrame){
      
    var h1 = mFrame.document.body.offsetHeight;
      
    var h2 = mFrame.document.body.scrollHeight;
      
    if(mFrame.moduleRight != null){
          
    var h3 = mFrame.moduleRight.document.body.scrollHeight;
        
    if(h3 > h2) h2 = h3;
      }
      
    return h2;
    }

    /**
     * 設置子內嵌頁面的高度.
     * 通過設置iframe所在table的高度來調整。
     
    */
    function initFrameHeight(frame,hFrame){
      
    var tbl = frame.document.getElementById('tblMainFrame');
      tbl.style.height 
    = hFrame;
    }

    3、其他設置
    主頁面(main.jsp),在加載完畢(onload)、窗口大小調整(onresize),以及iframe的加載完畢時,需調用:handleFrameLoad,代碼如下:
    <html>
       
      
    <body onload="handleFrameLoad();" onResize="handleFrameLoad();">
       
      
    <iframe src="" id="mainFrame" name="mainFrame" border=0 width=100% height=100% frameborder="0" marginwidth="0" hspace="0" scrolling="no" onload="handleFrameLoad();"/>
       
      
    </body>
    </html

    其他內嵌頁如下(注:此處的iframe高度設為100%,其高度由父頁面通過設置table<tblMainFrame>的高度來進行調整):
    <html>
       
      
    <body class="body" style="overflow:hidden;margin:0px;padding:0px">
        
    <table width="100%" height="100%" id="tblMainFrame" border="0" align="center" cellpadding="0" cellspacing="0">
         
    <tr>
           
    <td id='content' height=100%>
             
    <iframe src="about:blank" width="100%" height="100%" name="moduleRight" id="moduleRight" frameborder="0" hspace="0"/>
           
    </td>
         
    </tr>
        
    </table>
      
    </body>
    </html

    4、樣例下載: sample
    posted on 2008-01-17 13:56 josson 閱讀(9302) 評論(2)  編輯  收藏 所屬分類: web開發


    FeedBack:
    # re: iframe 高度自適應
    2008-09-08 22:44 | cssplay
    iframe自適應高度及其演示實例
    http://www.cssplay.org.cn/xhtml-tutorial/20080908/763.html  回復  更多評論
      
    # re: iframe 高度自適應
    2013-12-24 21:57 | 3a教程
    1909434428@qq.com  回復  更多評論
      
    <2013年12月>
    24252627282930
    1234567
    891011121314
    15161718192021
    22232425262728
    2930311234

    常用鏈接

    留言簿(3)

    隨筆分類

    隨筆檔案

    收藏夾

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 国产男女猛烈无遮档免费视频网站| 99久热只有精品视频免费看| 在线免费观看韩国a视频| 亚洲国产成a人v在线| 黄色网址免费大全| 亚洲人成免费网站| 18禁成年无码免费网站无遮挡 | 久久不见久久见中文字幕免费| 亚洲国产成人va在线观看网址| 在线天堂免费观看.WWW| 亚洲色大成网站www| 免费高清资源黄网站在线观看| 激情无码亚洲一区二区三区| 国产免费变态视频网址网站 | 亚洲国产精品自在线一区二区| 丝瓜app免费下载网址进入ios| 亚洲国产精品无码AAA片| 一级毛片免费播放| 亚洲人成电影院在线观看| 大陆一级毛片免费视频观看| 国产成人亚洲精品播放器下载| 亚洲日韩精品无码专区网站| a级毛片免费观看视频| 亚洲视频在线观看地址| 成年人在线免费看视频| 一级白嫩美女毛片免费| 亚洲天堂男人天堂| 卡1卡2卡3卡4卡5免费视频| 无码日韩人妻AV一区免费l| 亚洲级αV无码毛片久久精品| 久久久久久精品免费看SSS| 午夜亚洲国产理论片二级港台二级| 国产黄色一级毛片亚洲黄片大全 | 亚洲6080yy久久无码产自国产| 不卡精品国产_亚洲人成在线| 99热免费在线观看| 美女被爆羞羞网站在免费观看 | 在线亚洲午夜片AV大片| 久久久久久久亚洲精品| 波多野结衣免费在线观看| 日韩精品免费一线在线观看|