建立Context.js
import React from 'react'; const DocsContext = React.createContext(); export default DocsContext;
父组件:
import DocsContext from './docsContext';
import Children from './chlidren';
class Person extends Component {
constructor(props) {
super(props);
this.state = { id:3 }
this.docsRef = React.createRef(null);
}
//父组件获取子组件传过来的值,做处理 getDetail = item => {
console.log(item)
//父组件调用子组件的方法
this.docsRef.current && this.docsRef.current.getList();
} <DocsContext.Provider value={{ getDetail:val => this.getDetail(val)}} > <Children id={this.state.id} childRef={this.docsRef} />
</DocsContext.Provider> }
子组件:
import React, {useContext,useImperativeHandle} from 'react';
import DocsContext from './docsContext'; const Children: React.FC = ({id, childRef}) => { const values = useContext(DocsContext); //子组件调用父组件方法 const handle = (item)=>{ values.getDetail(item); }
const queryFileList = ()=>{}
useImperativeHandle(childRef, () => ({
getList: () => {
queryFileList();
},
}));
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!