跨域情况下如何通过 javascript 获取目标网址网页高度
在跨域的情况下,获取其他网页的高度可能有所限制。以下是一个需要考虑的示例:
登录后复制
由于父页面无法直接访问目标网页的 window 对象,因此无法直接获取其高度。要解决这个问题,可以考虑以下解决方案:
使用 postmessage api
立即学习“Java免费学习笔记(深入)”;
postmessage api 允许页面对不同域进行通信。要使用此 api,需要在目标网页和父网页中分别实现消息发送和接收功能。具体步骤如下:
在父页面中,添加以下脚本:
const iframe = document.getelementbyid('c_iframe');iframe.onload = () => { // 向目标网页发送消息 iframe.contentwindow.postmessage('getheight', '*');};window.addeventlistener('message', (event) => { if (event.origin !== 'www.baidu.com') { return; } // 接收目标网页返回的高度并设置 iframe 高度 const height = event.data; iframe.height = height;});
登录后复制在目标网页中,添加以下脚本:
window.addEventListener('message', (event) => { if (event.data !== 'getHeight') { return; } // 向父页面发送网页高度 const height = document.documentElement.offsetHeight; event.source.postMessage(height, '*');});
登录后复制
注意:如果无法控制目标网页,此解决方案将无法使用。此时,获取目标网页高度是不可能的。
以上就是跨域情况下,如何通过 JavaScript 获取目标网页的高度?的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2654489.html