zoukankan      html  css  js  c++  java
  • 利用html5 postMessage接口跨域设置iframe大小

    <!doctype html>
    <html>
        <head>
            <title>Document A</title>
            <meta charset="utf-8">
        </head>
        <body>
            <iframe src="http://remote-domain.com:8080/document-B.html" id="zino_iframe"></iframe>
            <script type="text/javascript">
            var zino_resize = function (event) {
                if (event.origin !== "http://remote-domain.com:8080") {
                    return;
                }
                var zino_iframe = document.getElementById('zino_iframe');
                if (zino_iframe) {
                    zino_iframe.style.height = event.data + "px";
                }
            };
            if (window.addEventListener) {
                window.addEventListener("message", zino_resize, false);
            } else if (window.attachEvent) {
                window.attachEvent("onmessage", zino_resize);
            }
            </script>
        </body>
    </html>
    
    <!doctype html>
    <html>
        <head>
            <title>Document B</title>
            <meta charset="utf-8">
            <script type="text/javascript">
            function iframe_resize(){
                var body = document.body,
                html = document.documentElement,
                height = Math.max(body.scrollHeight, body.offsetHeight, 
    	        html.clientHeight, html.scrollHeight, html.offsetHeight);
                if (parent.postMessage) {
                    parent.postMessage(height, "http://my-domain.com");
                }
            }
            </script>
        </head>
        <body onload="iframe_resize();">
            <h4>Document B</h4>
    	<p>Cross-Domain Iframe</p>
        </body>
    </html>
    

    Normally, documents on different pages are able to communicate between each other only if their domains, protocols and ports match up. HTML 5 specification comes with window.postMessage, which provides cross-domain communication between scripts.

    Syntax

    window.postMessage(message, targetOrigin, [transfer]);

    message
    Messages can be nested objects and arrays, can contain JavaScript values (strings, numbers, Dates, etc), and can contain certain data objects such as File Blob, FileList, and ArrayBuffer objects.
    targetOrigin
    The value must be either asterisk *, slash / or absolute URL. Otherwise a SyntaxError exception will be throw. If you know the window location, you should always provide this specific location instead of just putting an asterisk *
    transfer (Optional)
    These objects are transferred with the message, and they are no longer usable on the sending side.
  • 相关阅读:
    tabbar 旋转指定的页面
    GDAL中文路径不能打开&Shp文件字段属性值中文乱码
    Project : error PRJ0019: 工具从"Moc'ing xxx.h..."
    详解Android中的屏幕方向
    qt中获取文件路径和文件名
    vs2005下Qt项目中修改exe图标的方法
    Qt & C/C++统计运行时间
    Qt 中Treewidget添加右键菜单
    QT 中文乱码解决方案
    Qt多线程应用QRunnable显示进度条示例
  • 原文地址:https://www.cnblogs.com/kzwrcom/p/6443172.html
Copyright © 2011-2022 走看看