jquery ajax應用中iframe自適應高度問題解決方案_javascript技巧

來源:互聯網
上載者:User

iframe自適應高度本身是很簡單的方法,就是在頁面載入完成後,重新計算一下高度即可。

代碼如下:

複製代碼 代碼如下:

//公用方法:設定iframe的高度以保證全部顯示資料
//function SetPageHeight() {
//    var iframe = getUrlParam('ifname');
//    var myiframe = window.parent.document.getElementById(iframe);
//     iframeLoaded(myiframe);
//}
var iframeLoaded = function (iframe) {
    if (iframe.src.length > 0) {
        if (!iframe.readyState || iframe.readyState == "complete") {
            var bHeight =
            iframe.contentWindow.document.body.scrollHeight;
            var dHeight =
            iframe.contentWindow.document.documentElement.scrollHeight;
            var height = Math.max(bHeight, dHeight);
            iframe.height = height;
        }
    }
}
//分頁時重新設定 iframe 高度 ; 修改後:iframe.name = iframe.id
var reSetIframeHeight = function()
{
    try {
        var oIframe = parent.document.getElementById(window.name);
        oIframe.height = 100;
        iframeLoaded(oIframe);
    }
    catch (err)
    {
        try {
         parent.document.getElementById(window.name).height = 1000;
          } catch (err2) { }
    }
}

調用reSetIframeHeight();方法即可。

但是還有一種情況就是使用jquery ajax請求資料,資料都是在body load完成後,還在進行http請求,這時候沒有資料佔據視窗高度,reSetIframeHeight方法無法計算出來高度。

這時候,我們想到一個方法:ajax什麼時候能夠執行完成,當然是Complete事件是執行完成。

但是我們也不能在每一個頁面裡的ajax Complete事件中添加處理。這裡就用到了jquery ajax的全域變數。

處理ajax和iframe自適應的代碼:

複製代碼 代碼如下:
var sendcount = 0;
var completecount = 0;
// 添加ajax全域事件處理。
reSetIframeHeight();
$(document).ajaxStart(function (a, b, c) {
}).ajaxSend(function (e, xhr, opts) {
    sendcount++;
}).ajaxError(function (e, xhr, opts) {
}).ajaxSuccess(function (e, xhr, opts) {
}).ajaxComplete(function (e, xhr, opts) {
    completecount++;
        reSetIframeHeight();

}).ajaxStop(function () {
});

先執行一下reSetIframeHeight,再在每個ajax完成後調用reSetIframeHeight。

經過測試有效。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.