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);
相关推荐
GISer_Jing2 小时前
Taro多端开发
前端·react.js·taro
coding随想3 小时前
ESM + TypeScript:零配置实现类型安全的现代开发
安全·ubuntu·typescript
程序员林北北7 小时前
【前端进阶之旅】一种新的数据格式:TOON
前端·javascript·vue.js·react.js·typescript·json
容沁风8 小时前
react路由Cannot GET错误
前端·react.js·前端框架·sharp7
Wect9 小时前
LeetCode 104. 二叉树的最大深度:解题思路+代码解析
前端·算法·typescript
Wect9 小时前
LeetCode 100. 相同的树:两种解法(递归+迭代)详解
前端·算法·typescript
哆啦A梦158810 小时前
Vue3魔法手册 作者 张天禹 012_路由_(二)
前端·vue.js·typescript
We་ct10 小时前
LeetCode 100. 相同的树:两种解法(递归+迭代)详解
前端·算法·leetcode·链表·typescript
哆啦A梦158810 小时前
Vue3魔法手册 作者 张天禹 08_回顾TS中的-接口-泛型-自定义事件
前端·vue.js·typescript
xjf771111 小时前
TypDom框架分析
javascript·typescript·前端框架·typedom