首页 > web前端 > H5教程 > 正文

详解HTML5中的消息通信代码

零下一度
发布: 2017-04-22 14:38:51
原创
2085人浏览过

html5支持跨文档消息通信(cross-document messaging)。

既然使用到消息通信,那么必然有事件(event)产生。根据事件的产生和消费,我们能够找到发送者和接收者,也就是Sender和Listener。

其中Litener需要做如下的工作:

  1. 编写一个消息处理函数;

  2. 将消息处理函数注册:addEventListener('message', function, false);

    立即学习前端免费学习笔记(深入)”;

其中Sender需要做以下工作:

  1. postMessage('this is a message', 'http://www.php.cn');

事件对象event中包含的成员包括:

通义灵码
通义灵码

阿里云出品的一款基于通义大模型的智能编码辅助工具,提供代码智能生成、研发智能问答能力

通义灵码31
查看详情 通义灵码
  1. data:传递的数据;

  2. origin:origin,origin包括三要素:主机、协议、端口;

  3. source:来源对象;

好了,下面我们看一个例子,这个例子展示了在页面中嵌套页面并且向子页面发送消息:

父页面如下:

<!DOCTYPE html>
<html lang="en">

<!-- 
    crossDomain.html by Bill Weinman 
    <http://bw.org/contact/>
    created 2011-04-16

    Copyright (c) 2011 The BearHeart Group, LLC
    This file may be used for personal educational purposes as needed. 
    Use for other purposes is granted provided that this notice is
    retained and any changes made are clearly indicated as such. 
-->

<head>
    <title>
        HTML5 Messaging Template File (One)
    </title>
    <link rel="stylesheet" type="text/css" href="../CSS/main.css">
    <style>
        #frameTwo {
            float: left;
            width: 500px;
            height: 400px;
            margin: 0 5px;
            padding: 3px;
            border-top: 2px solid #3c6b92;
            border-left: 2px solid #3c6b92;
            border-bottom: 2px solid #ccc;
            border-right: 2px solid #ccc;
        }
        #content { height: 500px; }
    </style>
    <script type="text/javascript">
		// 域名
        var originTwo = 'http://two.3sn.net';
		// URL地址
        var URLTwo = 'http://two.3sn.net/H5Msg/ExerciseFiles/Chap01/crossDomainTwo.html';
        var windowTwo = null;

        function handleMessage(event) {
			// 判断源区域
            if (event.origin == originTwo) {
                if(!windowTwo) windowTwo = event.source;
                log('message from origin: ' + event.origin);
                log(event.data);
				// 发送消息
                windowTwo.postMessage('this is from windowOne!', originTwo);
                log('message sent back to windowTwo');
            } else {
                dispError('message from untrusted origin: ' + event.origin);
            }
        }


        function init() {
			// 添加消息处理函数
		    window.addEventListener("message", handleMessage, false);
            window.onerror = windowErrorHandler;
            log('this is windowOne');
            log('host: ' + location.host);
			
			// load two页面
            element('frameTwo').src = URLTwo;   // load the frame
        }

        // ##### Utilities #####

        // shortcut for getElementById
        function element(id) { return document.getElementById(id); }

        function clearDisp() {
            element('pageResults').innerHTML = '';
            element('message').innerHTML = '';
            element('message').className = '';
        }

        function dispMessage(message) {
            m = element('message');
            m.className = 'message';
            if(m.textContent.length > 0) {
                m.innerHTML += '<br />' + message;
            } else m.innerHTML = message;
        }

        function windowErrorHandler(message, filename, lineno) {
            dispError(message + ' (' + filename + ':' + lineno + ')' );
            return true;
        };

        function dispError(errorMessage) {
            element('pageResults').innerHTML += 
                errorMessage ? '<p class="error">' + errorMessage + '</p>\n' : '';
        }

        function log(m) {
            if(m.length < 1) return;
            logElement = element('log');
            if(logElement.textContent.length > 0) logElement.innerHTML += '<br />';
            logElement.innerHTML += nowTimeString() + ' ' + m;
        }

        function nowTimeString() {
            var d = new Date();
            return numToString(d.getUTCHours(), 2) + ':' + numToString(d.getUTCMinutes(), 2) + ':' +
                numToString(d.getUTCSeconds(), 2) + '.' + numToString(d.getUTCMilliseconds(), 3);
        }

        function numToString( num, len ) {
            var num = num + '';
            while(num.length < len) num = '0' + num;
            return num;
        }

        window.onload = init;

    </script>
</head>

<body>

<p id="content">

    <h1> 
        HTML5 Messaging Template File (One)
    </h1>

    <p id="message"></p>
    <p id="pageResults"></p>

    <iframe id="frameTwo">
        <p>Your browser doesn't support the iFrame feature</p>
    </iframe>

    <p id="log" style="font-family: monospace"></p>

</p>
</body>
</html>
登录后复制
<!DOCTYPE html>
<html lang="en">

<!-- 
    crossDomain.html by Bill Weinman 
    <http://bw.org/contact/>
    created 2011-04-16

    Copyright (c) 2011 The BearHeart Group, LLC
    This file may be used for personal educational purposes as needed. 
    Use for other purposes is granted provided that this notice is
    retained and any changes made are clearly indicated as such. 
-->

<head>
    <title>
        HTML5 Messaging Template File (Two)
    </title>
    <link rel="stylesheet" type="text/css" href="../CSS/main.css">
    <script type="text/javascript">
        var originOne = 'http://one.3sn.net';

        function handleMessage(event) {
            if (event.origin == originOne) {
                log('message from origin: ' + event.origin);
                log(event.data);
            } else {
                dispError('message from untrusted origin: ' + event.origin);
            }
        }

        // ##### Init #####

        function init() {
            window.onerror = windowErrorHandler;    // addEventListener doesn't provide the right error object in Firefox
            window.addEventListener("message", handleMessage, false);
            log('this is windowTwo');
            log('host: ' + location.host);
            var windowOne = parent;
            windowOne.postMessage('this is from windowTwo!', originOne);
            log('message sent to windowOne');
        }

        // ##### Utilities #####

        // shortcut for getElementById
        function element(id) { return document.getElementById(id); }

        function clearDisp() {
            element('pageResults').innerHTML = '';
            element('message').innerHTML = '';
            element('message').className = '';
        }

        function dispMessage(message) {
            m = element('message');
            m.className = 'message';
            if(m.textContent.length > 0) {
                m.innerHTML += '<br />' + message;
            } else m.innerHTML = message;
        }

        function windowErrorHandler(message, filename, lineno) {
            dispError(message + ' (' + filename + ':' + lineno + ')' );
            return true;
        };

        function dispError(errorMessage) {
            element('pageResults').innerHTML += 
                errorMessage ? '<p class="error">' + errorMessage + '</p>\n' : '';
        }

        function log(m) {
            if(m.length < 1) return;
            logElement = element('log');
            if(logElement.textContent.length > 0) logElement.innerHTML += '<br />';
            logElement.innerHTML += nowTimeString() + ' ' + m;
        }

        function nowTimeString() {
            var d = new Date();
            return numToString(d.getUTCHours(), 2) + ':' + numToString(d.getUTCMinutes(), 2) + ':' +
                numToString(d.getUTCSeconds(), 2) + '.' + numToString(d.getUTCMilliseconds(), 3);
        }

        function numToString( num, len ) {
            var num = num + '';
            while(num.length < len) num = '0' + num;
            return num;
        }

        window.onload = init;

    </script>
</head>

<body>

<p id="content">

    <h1> 
        HTML5 Messaging Template File (Two)
    </h1>

    <p id="message"></p>
    <p id="pageResults"></p>
    <p id="log" style="font-family: monospace"></p>

</p>
</body>
</html>
登录后复制

需要学习html5的同学请关注php中文网html5视频教程,众多html5在线视频教程可以免费观看!

以上就是详解HTML5中的消息通信代码的详细内容,更多请关注php中文网其它相关文章!

相关标签:
HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号