跨域情况下,如何通过 JavaScript 获取目标网页的高度?

跨域情况下,如何通过 javascript 获取目标网页的高度?

跨域情况下如何通过 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

(0)
上一篇 2025年3月7日 09:26:45
下一篇 2025年3月7日 09:26:51

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论