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
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>
|