You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

36 lines
1.3 KiB
HTML

<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta
name="viewport"
content="width=device-width, initial-scale=1.0"
/>
<title>Child Window</title>
</head>
<body>
<div>我是子窗口</div>
<button id="sendMsg">点击给父窗口发送信息</button>
<script>
let parentWindow;
// 监听来自父窗口的消息
window.addEventListener('message', (event) => {
// 验证消息来源
if (event.origin === 'https://your-parent-domain.com') {
console.log('接受父窗口跨域跨标签消息', event.data);
parentWindow = event.source;
}
});
document.getElementById('sendMsg').onclick = function () {
// 方式一,必须依赖父窗口先发消息给子窗口
// parentWindow.postMessage('给父窗口传跨域跨标签消息', 'https://your-parent-domain.com');
// 方式二,可以直接给父窗口发消息
window.opener.postMessage('给父窗口传跨域跨标签消息', 'https://your-parent-domain.com');
};
</script>
</body>
</html>