在两个不同域名的网页之间传递消息和调用方法,可以使用跨域消息传递(Cross-origin communication)技术,其中最常用的是窗口.postMessage()方法。postMessage()方法允许不同来源的窗口进行受限通信,以实现跨域消息传递。
以下是使用postMessage()的一个基本示例:假设有两个域名:domainA.com和domainB.com。
在domainA.com中的代码示例:
<!DOCTYPE html>
<html>
<head>
<title>Domain A</title>
<script>
function sendMessage() {
var iframe = document.getElementById('iframeB');
var message = {data: 'Hello from Domain A'};
iframe.contentWindow.postMessage(JSON.stringify(message), 'https://domainB.com');
}
</script>
</head>
<body>
<h1>Domain A</h1>
<buttonBfwOnclick="sendMessage()">Send Message to Domain B</button>
<iframe id="iframeB" src="https://domainB.com" width="100%" height="300px"></iframe>
</body>
</html>
在domainB.com中的代码示例:
<!DOCTYPE html>
<html>
<head>
<title>Domain B</title>
<script>
function receiveMessage(event) {
if (event.origin !== 'https://domainA.com') return;
var message = JSON.parse(event.data);
console.log('Received message:', message.data);
}
window.addEventListener('message', receiveMessage, false);
</script>
</head>
<body>
<h1>Domain B</h1>
</body>
</html>
在这个示例中,domainA.com中的sendMessage()函数将消息发送到domainB.com中的iframe。在domainB.com中,我们使用window.addEventListener()监听message事件,当domainB.com收到消息时,会触发receiveMessage函数。
请注意,为了安全起见,接收消息的页面需要检查event.origin属性,以确保消息是从期望的发送方发出的。这可以防止不受信任的第三方页面向您的页面发送消息。
这种方法适用于不同域名的网页之间的通信,包括父窗口与子iframe、两个相互独立的窗口或标签页等场景。
还可以让两个不同域名的网页同时连接共同的服务器,通过服务器来实现消息通讯交换。
网友回复
python如何实现声纹识别用户进行验证?
在哪可找到各种影视经典角色的配音并克隆音色根据文本说话?
阿里通义大模型哪些是支持多模态的api的ai模型?
js如何实现浏览器中离线语音唤醒语音聊天小助手?
浏览器中如何将WebM视频转成mp4视频?
parlant如何改成qwen 的apikey与baseurl?
如何写一个chrome插件实现截屏自动生成步骤图文教程转成pdf或网页?
python如何通过阿里云的api对域名进行解析和ecs主机服务器进行启动停止等操作?
Tesla Robotaxi可以让特斯拉车自动无人驾驶跑滴滴为车主赚钱,国内以后也会这样吗?
有没有可以监控安卓手机上的app打开后偷偷摸摸做了啥的监控软件?