前端内嵌Iframe页面,同源非同源消息通信

本文介绍了如何在前端通过Iframe实现跨域通信,主要利用了Window的postMessage方法。提供了详细的parent.html和children.html的代码示例,详细解析了同源与非同源下的消息传递机制。
摘要由CSDN通过智能技术生成

参考文档地址:https://developer.mozilla.org/zh-CN/docs/Web/API/Window/postMessage

原理基于postMessage。

demo例子:

parent.html

<!DOCTYPE html>
<html>
    <head></head>
    <body>
        <h1>父亲页面</h1>
        <button onclick="sendMeg()">发送数据</button>
        <iframe src="children.html" width="100%" height="200px" id="child"></iframe>
    </body>
    <script>
        function sendMeg(){
            var iframe = document.getElementById("child")
            iframe.contentWindow.postMessage('父页面传送的数据','*');
        }
        function callback(){
            console.log(回调)
        }
        // 监听传送到父页面的数据
        window.addEventListener('message',function(data){
            console.
对于跨域的情况,由于浏览器的同源策略限制,直接使用 jQuery 的方法是无法获取到嵌套的跨域 iframe 中的元素的。 不过,可以通过使用 postMessage API 进行跨域通信来实现获取跨域 iframe 中的元素。以下是一个示例: 在父页面(当前页面)中: ```javascript // 监听嵌套的跨域 iframe 发送的消息 window.addEventListener('message', function(event) { if (event.origin !== 'https://example.com') { // 设置跨域 iframe 的域名 return; } // 获取嵌套的 iframe 发送过来的数据 var data = event.data; // 在此处处理接收到的数据,可以获取嵌套 iframe 中的元素 var element = $(data).find('#element'); }); // 向嵌套的跨域 iframe 发送消息 var nestedIframe = document.getElementById('nestedIframe'); // 获取嵌套 iframe 的 DOM 元素 var message = '需要获取元素'; // 发送给嵌套 iframe消息 nestedIframe.contentWindow.postMessage(message, 'https://example.com'); // 设置跨域 iframe 的域名 ``` 在嵌套的跨域 iframe 中: ```javascript // 监听父页面发送过来的消息 window.addEventListener('message', function(event) { if (event.origin !== 'https://parent.com') { // 设置父页面的域名 return; } // 获取父页面发送过来的数据 var data = event.data; // 在此处处理接收到的数据,可以获取嵌套 iframe 中的元素 var element = $(data).find('#element'); // 将需要获取的元素发送回父页面 event.source.postMessage(element.html(), 'https://parent.com'); // 设置父页面的域名 }); ``` 请注意,上述代码中的 `'https://example.com'` 是跨域 iframe 的域名,`'https://parent.com'` 是父页面的域名,需根据实际情况进行设置。 通过使用 postMessage API,可以实现跨域 iframe 之间的通信,并在父页面中获取到嵌套的跨域 iframe 中的元素。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值