iframe事件冒泡的问题

在React项目中,由于iframe的事件无法冒泡到父页面,导致问题出现。文章探讨了这个问题的原因,并提出了两种解决方法:1. 设置`document.domain`使iframe和父页面在同一主域;2. 使用`postMessage`进行跨窗口通信,详细阐述了两种方法的实现思路和适用场景。
摘要由CSDN通过智能技术生成

iframe事件冒泡的问题

在react中遇到了遇到一个问题,导致的原因就是:iframe的事件只能冒泡到iframe下的window,不能冒泡到父页面的window。

例子图

实现思路:通过监听iframe的点击事件,使用js实现自动点击button,来收起popover。(存在问题:iframe跨域)

在本地开发时,只能把项目跑在本地的不同端口上,所以是跨域的,线上环境不跨域。(如果想要实现本地模拟正式线上环境,需要本地启动nginx服务器代理到相同端口下)

方法1:domain

跨域报错

因为此时两个页面的主域都是example.com,所以在两个页面中都使用document.domain='example.com'设置下主域相同,设置了之后就不会有上面的报错(虽然线上环境不跨域,但是想要iframe之间进行通信,还是必须要使用document.domain设置下)

方法2:postMessage

父页面:


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值