`

iframe自适应高度

 
阅读更多

父页:

<script type="text/javascript" src="FrameManager.js"></script>

<iframe id="frame-one" scrolling="no" frameborder="0" src="子页面.html" width="100%" onload="FrameManager.registerFrame(this)"></iframe>

 

 

 

 

iframe子页:

 

<script src="frame.js" type="text/javascript">
</script>
<script type="text/javascript">
window.onload = function(event) {
            window.setInterval(publishHeight, 300);
        }
</script>

 

 

 

----------------------------------------------------------------------

js文件代码:

FrameManager.js

 

var FrameManager = {

    currentFrameId : '',
    currentFrameHeight : 0,
    lastFrameId : '',
    lastFrameHeight : 0,
    resizeTimerId : null,

    init: function() {
   
        if (FrameManager.resizeTimerId == null) {
       
            FrameManager.resizeTimerId = window.setInterval(FrameManager.resizeFrames, 500);
           
        }
       
    },

    resizeFrames: function() {
   
        FrameManager.retrieveFrameIdAndHeight();

        if ((FrameManager.currentFrameId != FrameManager.lastFrameId) || (FrameManager.currentFrameHeight != FrameManager.lastFrameHeight)) {
           
            var iframe = document.getElementById(FrameManager.currentFrameId.toString());

            if (iframe == null) return;

            iframe.style.height = FrameManager.currentFrameHeight.toString() + "px";

            FrameManager.lastFrameId = FrameManager.currentFrameId;
            FrameManager.lastFrameHeight = FrameManager.currentFrameHeight;
            window.location.hash = '';
           
        }
       
    },

    retrieveFrameIdAndHeight: function() {
   
        if (window.location.hash.length == 0) return;

        var hashValue = window.location.hash.substring(1);

        if ((hashValue == null) || (hashValue.length == 0)) return;

        var pairs = hashValue.split('&');

        if ((pairs != null) && (pairs.length > 0)) {
       
            for(var i = 0; i < pairs.length; i++) {
           
                var pair = pairs[i].split('=');

                if ((pair != null) && (pair.length > 0)) {
               
                    if (pair[0] == 'frameId') {
                   
                        if ((pair[1] != null) && (pair[1].length > 0)) {
                       
                            FrameManager.currentFrameId = pair[1];
                        }
                    } else if (pair[0] == 'height') {
                   
                        var height = parseInt(pair[1]);

                        if (!isNaN(height)) {
                       
                            FrameManager.currentFrameHeight = height;
                            FrameManager.currentFrameHeight += 15;
                           
                        }
                    }
                }
            }
        }
       
    },

    registerFrame: function(frame) {
   
        var currentLocation = location.href;
        var hashIndex = currentLocation.indexOf('#');

        if (hashIndex > -1) {
       
            currentLocation = currentLocation.substring(0, hashIndex);
        }

        frame.contentWindow.location = frame.src + '?frameId=' + frame.id + '#' + currentLocation;
       
    }
};

window.setTimeout(FrameManager.init, 300);

 

 

 

----------------------------------

frame.js

 

function publishHeight() {

    if (window.location.hash.length == 0) return;

    var frameId = getFrameId();

    if (frameId == '') return;

    var actualHeight = getBodyHeight();
    var currentHeight = getViewPortHeight();

    if  (Math.abs(actualHeight - currentHeight) > 15) {
        var hostUrl = window.location.hash.substring(1);

        hostUrl += "#";
        hostUrl += 'frameId=' + frameId;
        hostUrl += '&';
        hostUrl += 'height=' + actualHeight.toString();

        window.top.location = hostUrl;
    }
}

function getFrameId() {

    var qs = parseQueryString(window.location.href);
    var frameId = qs["frameId"];

    var hashIndex = frameId.indexOf('#');

    if (hashIndex > -1) {
        frameId = frameId.substring(0, hashIndex);
    }

    return frameId;
   
}

function getBodyHeight() {

    var height,
        scrollHeight,
        offsetHeight;

    if (document.height) {
   
        height = document.height;
       
    } else if (document.body) {
   
        if (document.body.scrollHeight) {
            height = scrollHeight = document.body.scrollHeight;
        }
       
        if (document.body.offsetHeight) {
            height = offsetHeight = document.body.offsetHeight;
        }
       
        if (scrollHeight && offsetHeight) {
            height = Math.max(scrollHeight, offsetHeight);
        }
    }

    return height;
}

function getViewPortHeight() {

    var height = 0;

    if (window.innerHeight) {
        height = window.innerHeight - 18;
    } else if ((document.documentElement) && (document.documentElement.clientHeight)) {
        height = document.documentElement.clientHeight;
    } else if ((document.body) && (document.body.clientHeight)) {
        height = document.body.clientHeight;
    }

    return height;
   
}

function parseQueryString(url) {

    url = new String(url);
   
    var queryStringValues = new Object(),
        querystring = url.substring((url.indexOf('?') + 1), url.length),
        querystringSplit = querystring.split('&');

    for (i = 0; i < querystringSplit.length; i++) {
        var pair = querystringSplit[i].split('='),
            name = pair[0],
            value = pair[1];

        queryStringValues[name] = value;
    }

    return queryStringValues;
   
}

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics