ai设计logo免费网站,桂林网站建设科技有限公司,在线网站制作系统源码,廖雪峰的网站怎么做的在react16之后带来了hooks之后#xff0c;确实方便了很多组件开发#xff0c;也加快了函数式编程的速度#xff0c;但是当你通过useRef获取子组件的时候#xff0c;又恰好子组件是一个函数组件#xff0c;那么将会报一个错误#xff1a;报这个错误的主要原因是函数组件没…在react16之后带来了hooks之后确实方便了很多组件开发也加快了函数式编程的速度但是当你通过useRef获取子组件的时候又恰好子组件是一个函数组件那么将会报一个错误报这个错误的主要原因是函数组件没有实例对象所以你没办法通过ref获取子组件实例 Warning: Function components cannot be given refs. Attempts to access this ref will fail. Did you mean to use React.forwardRef()? 所以它提示你是否使用 forwardRef 将子组件包裹一下
包裹一下之后就不会报错了而且也可以拿到子组件实例了但是子组件实例上面啥都没有是一个空对象
这个时候还要在子组件上暴露出去几个函数才可以让父组件拿到子组件实例上的函数 // 暴露出去的实例对象应该有哪些函数useImperativeHandle(ref, () ({saveMd: () {console.log(保存markdown内容);localStorage.setItem(notes, htmlString)}})) 这时候再看一下获取到的子组件实例就有了子组件暴露出去的函数就可以调用了