程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 更多關於編程 >> iframe 高度設置

iframe 高度設置

編輯:更多關於編程

     謂iframe自適應高度,就是,基於界面美觀和交互的考慮,隱藏了iframe的border和scrollbar,讓人看不出它是個iframe。如果iframe始終調用同一個固定高度的頁面,我們直接寫死iframe高度就可以了。而如果iframe要切換頁面,或者被包含頁面要做DOM動態操作,這時候,就需要程序去同步iframe高度和被包含頁的實際高度了。

    如果iframe的高度沒有確定,那將是初始的高度。
    iframe是網頁中的一部分,其大小還要受到網頁的限制,設置最高可以使用height="100%"。
    基本上解決iframe超出的高度都是增加了滾動條來實現的,很簡單,如果你iframe中的信息超出了一屏幕,你就必須使用滾動條了。

    開始用的時候還不行,後來發現是因為js跨域問題,沒有權限。後來設置了window.document.domain 就可以了,用的是jquery代碼2方法。

    跨域下的iframe自適應高度

    跨域的時候,由於js的同源策略,父頁面內的js不能獲取到iframe頁面的高度。需要一個頁面來做代理。
    方法如下:假設www.a.com下的一個頁面a.html要包含www.b.com下的一個頁面c.html。
    我們使用www.a.com下的另一個頁面agent.html來做代理,通過它獲取iframe頁面的高度,並設定iframe元素的高度。

    a.html中包含iframe:
    <iframe src="http://www.b.com/c.html" id="Iframe" frameborder="0" scrolling="no" style="border:0px;"></iframe>

    在c.html中加入如下代碼:
    <iframe id="c_iframe"  height="0" width="0"  src="http://www.a.com/agent.html" style="display:none" ></iframe>
    <script type="text/javascript">
        (function autoHeight(){
            var b_width = Math.max(document.body.scrollWidth,document.body.clientWidth);
            var b_height = Math.max(document.body.scrollHeight,document.body.clientHeight);
            var c_iframe = document.getElementById("c_iframe");
            c_iframe.src = c_iframe.src+"#"+b_width+"|"+b_height; 
        })();
    </script>

    最後,agent.html中放入一段js:
    <script type="text/javascript">
        var b_iframe = window.parent.parent.document.getElementById("Iframe");
        var hash_url = window.location.hash;
        if(hash_url.indexOf("#")>=0){
            var hash_width = hash_url.split("#")[1].split("|")[0]+"px";
            var hash_height = hash_url.split("#")[1].split("|")[1]+"px";
            b_iframe.style.width = hash_width;
            b_iframe.style.height = hash_height;
        }
    </script>
    agent.html從URL中獲得寬度值和高度值,並設置iframe的高度和寬度(因為agent.html在www.a.com下,所以操作a.html時不受JavaScript的同源限制)

    超級簡單的方法,也不用寫什麼判斷浏覽器高度、寬度啥的。
    下面的兩種方法自選其一就行了。一個是放在和iframe同頁面的,一個是放在test.html頁面的。
    注意別放錯地方了哦。

    下面是其他兩種方法:
    iframe代碼,注意要寫ID

    <iframe src="test.html" id="main" width="700" height="300" frameborder="0" scrolling="auto"></iframe>

    jquery代碼1:

    //注意:下面的代碼是放在test.html調用
    $(window.parent.document).find("#main").load(function(){
    var main = $(window.parent.document).find("#main");
    var thisheight = $(document).height()+30;
    main.height(thisheight);
    });

    jquery代碼2:

    //注意:下面的代碼是放在和iframe同一個頁面調用
    $("#main").load(function(){
    var mainheight = $(this).contents().find("body").height()+30;
    $(this).height(mainheight);
    }); 

    第二種有效,不過要注意一點是,增加的JS要寫在iframe下面,放在頭部是測試沒有效果。
    測試代碼:
    <iframe id="mainframe" name="mainframe" marginwidth="0" marginheight="0" src="/Home/Activitylist" frameborder="0" width="100%" scrolling="no" height="100%"></iframe>
    <script type="text/javascript">
    //注意:下面的代碼是放在和iframe同一個頁面調用,放在iframe下面
    $("#mainframe").load(function () {
    var mainheight = $(this).contents().find("body").height() + 30;
     $(this).height(mainheight);
    });
    </script>

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved