swst 2021-06-23 11:36 采纳率: 100%
浏览 32
已采纳

Javascript怎么获取iframe中字文档的元素

如题

在a.html中有如下iframe,初始display属性为none,并通过js实现点击切换display属性为block。

<div id="commodity_wrapper" class="iframe-wrapper" style="display: none">
  <iframe src="commodity_manage.html" ></iframe>
</div>

现在我想在b.html中通过id获取这个div,并实现点击将display再次设置为none。

我在网上查到的window.parent和window.opener貌似都不起作用。

目前不能实现功能的代码如下:

function toggle_invisible(id){
    let ele = window.parent.document.getElementById(id);
    ele.style.display = "none";
}

请问是我对这两个方法的用法有误,还是我应该用别的方法呢?

  • 写回答

3条回答 默认 最新

  • Null_Reference 2021-06-29 17:42
    关注

     

    //iframe向主页面传递事件//iframe页面
    window.parent.postMessage({refresh:'id'},'*');
    
    //主页面
    window.addEventListener('message',function(event){
         if(event.data.refresh){    //此处执行事件
        }
    })

    使用这种方式

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵