react useRef ts 编译报错 不能将类型“MutableRefObject<HTMLDivElement undefined>”分配给类型“LegacyRef<HTMLDivEleme

3 篇文章 0 订阅
3 篇文章 0 订阅

不能将类型“MutableRefObject<HTMLDivElement | undefined>”分配给类型“LegacyRef | undefined”。

1.没赋初值
2. useRef里面没写对类型

正确的列子

   const canvasRef = useRef<HTMLCanvasElement|null>(null)

/// ....


return <canvas ref={canvasRef }>
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个误通常是由于 `VNodeRef` 和 `Ref<Element>` 之间的类型不匹配造成的。为了解决这个问题,我们可以使用 `React.ForwardedRef` 类型,它是 `React.Ref` 的一个子类,专门用于在 `React.forwardRef` 中使用。 例如,假设我们有一个 `MyComponent` 组件,它使用了 `React.forwardRef`,但在使用组件时,获取的 `ref` 为 `null`,同时出现了上述的类型误。我们可以这样来解决: ```tsx import React from 'react'; interface MyComponentProps { // ... } const MyComponent = React.forwardRef<HTMLDivElement, MyComponentProps>((props, ref) => { return ( <div ref={ref}> {/* ... */} </div> ); }); export default MyComponent; ``` 使用 `React.ForwardedRef` 类型,将 `ref` 的类型设置为 `HTMLDivElement`,表示我们期望 `ref` 引用的是 `div` 元素。这样,我们就可以正确地获取 `ref` 了。 在使用组件时,需要使用 `React.createRef` 来创建一个 `ref` 对象,将其传递给 `MyComponent` 组件的 `ref` 属性。这样,`ref` 就可以正确地绑定到 `div` 元素上了。 ```tsx import React from 'react'; import MyComponent from './MyComponent'; function App() { const myComponentRef = React.createRef<HTMLDivElement>(); function handleClick() { myComponentRef.current?.focus(); } return ( <div> <MyComponent ref={myComponentRef} /> <button onClick={handleClick}>Focus Div</button> </div> ); } export default App; ``` 这样就能正确地获取 `ref` 了,同时也不会出现类型误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值