react17同源iframe父子页面相互调用方法

本文介绍了在React应用中如何与嵌套的第三方iframe进行交互,包括父子页面间的通信方法,以及如何搭建同源开发环境以方便调试。作者详细展示了将方法挂载到window对象,子页面调用父页面方法,以及父页面调用子页面方法的实现过程,同时还分享了使用PHP小皮搭建同源环境的步骤,尽管调试时需要不断打包,但为开发者提供了一种解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近制作一个大数据展示页面,需要嵌套第三方html,并进行相应的交互。
如下图:
在这里插入图片描述
其中A页面需要与第三方iframe进行交互,同时iframe选择公司或者园区时会回显到树选择器中。

先上解决办法

1,利用iframe进行父子页面通信,相互调用父子页面中的方法。(同源)
首先,我在react17中的index.js中把第三方需要调用我的方法挂载到window中

// 与3d交互的文件
import {webGl_web_iconClick} from '../src/http/webgl_web_iconClick'
window.webGl_web_iconClick=webGl_web_iconClick;

webgl_web_iconClick.js文件

export function webGl_web_iconClick(val) {
   alert('我是父组件中的方法:'+val);
  }

我们再创建一个html文件,作为传参调试的案例child(这个就是我们要嵌套的页面)

<!DOCTYPE html>
<html lang="zh-CN" >
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<body>
  <div class="content">
      <button onclick="btnClick()">子页面按钮</button>    
  </div> 
</body>
<script>
  function btnClick(){
    //调用父页面的方法
    parent.window.webGl_web_iconClick('我是子页面的参数');
  }
  window.frames.childFun=function(val){
    alert('我是子页面的方法!:'+val);
  }
</script>
</html>

在父页面来调用子页面的方法

	// 调用子组件的方法并传参
		useChildFun(){
			window.frames.iframe.childFun('我是父组件的参数!');
		}

render函数中新建一个dom来触发这个事件

<div onClick={this.useChildFun}>调用子页面的方法</div>

好嘞,俺们来看看效果
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
看提示框,我们的方法已经调用了,并且参数也已经传成功了!

如何搭建同源开发环境?

这个时候我借用了php的小皮,点击下载安装。
1,启用数据库跟服务器
在这里插入图片描述
2,创建网站节点并配置映射地址
在这里插入图片描述
3,将iframe的html与react打包的build文件放同一个文件夹
在这里插入图片描述
通过地址访问
在这里插入图片描述
react项目中iframe地址
在这里插入图片描述
这样我们就搭建好了同源开发环境,只是要调试的时候得不断得打包,会比较麻烦。

这是本程序汪开发过程中遇到得一些问题,希望对各位同学能起到一些借鉴作用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值