TS-React:useRef 使用

不能给 useRef 的 current 属性赋值,提示一下错误信息:

Cannot assign to 'current' because it is a read-only property.(不能给current属性复制,因为它是一个只读属性。)

代码如下所示:

typescript 复制代码
let cameraMediaStream = useRef<MediaStream>(null);

/**
 * 打开摄像头
 **/
const openCamera = async (cameraId = curCameraId) => {
    try {
      // 关闭已打开的摄像头
      if (cameraMediaStream) await closeCamera();
      // Cannot assign to 'current' because it is a read-only property.
      cameraMediaStream.current = await ImageCapture.openCamera({ cameraId, video: videoRef.current, width, height });
    }
    catch (err: any) {
    	// 错误信息提示...
    }
}

解决方案:将 current 属性变为非只读属性,useRef 的泛型参数中增加【| null】即可把 current 属性变为非只读属性。

typescript 复制代码
let cameraMediaStream = useRef<MediaStream | null>(null);
相关推荐
伍哥的传说40 分钟前
H3初识——入门介绍之常用中间件
前端·javascript·react.js·中间件·前端框架·node.js·ecmascript
G等你下课2 小时前
React 事件机制原理
前端·react.js
遂心_2 小时前
深入剖析React待办事项应用:Hooks、组件化与性能优化实战
前端·react.js·前端框架
小山不高2 小时前
react封装指令式组件
前端·react.js
爱学习的茄子2 小时前
深入解析React事件机制:从原生DOM到合成事件的演进
前端·react.js·面试
成遇5 小时前
Eslint基础使用
javascript·typescript·es6
前端小趴菜0511 小时前
React-React.memo-props比较机制
前端·javascript·react.js
摸鱼仙人~12 小时前
styled-components:现代React样式解决方案
前端·react.js·前端框架
ohMyGod_12318 小时前
React16,17,18,19新特性更新对比
前端·javascript·react.js
前端小趴菜0518 小时前
React-forwardRef-useImperativeHandle
前端·vue.js·react.js