iframe事件冒泡的问题

在React项目中,由于iframe的事件无法冒泡到父页面,导致问题出现。文章探讨了这个问题的原因,并提出了两种解决方法:1. 设置`document.domain`使iframe和父页面在同一主域;2. 使用`postMessage`进行跨窗口通信,详细阐述了两种方法的实现思路和适用场景。
部署运行你感兴趣的模型镜像

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

父页面:

<iframe
    ref={iframeRef}
    src={url}
    onLoad={iframeLoad}
    style={{ width: '100%', height: '99%', border: 'none' }}
    />

//监听message事件,获取iframe发来的消息
 useEventListener('message', e => {
    const message = e.data.message
    //当查看当前账号的pop打开时,点击iframe内容,也可关闭pop
    if (message?.click) {
      //找到触发按钮,并模拟点击,触发收起popover
      const HeaderSickNamePop = document.getElementsByClassName(
        'antd-pro-layouts-header-account-account ant-popover-open'
      )[0]
      if (HeaderSickNamePop) {
        HeaderSickNamePop.click()
      }
    }
  })

iframe页面:

useEffect(() => {
    const clickCallback = () => {
        window.parent.postMessage(
            {
                message: { click: true },
            },
            '*'
        )
    }
    window.addEventListener('click', clickCallback)
    return () => {
        window.removeEventListener('click', clickCallback)
    }
}, [])
//进入页面的时候将在iframe的window下全局监听点击事件,并向父页面发消息

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值