React--- 状态更新:何时需要拷贝,何时不需要?

遵从javascript的机制,基本类型不需要,引用类型需要

一、必须拷贝后更新的类型(引用类型)

1. 数组、对象(含多维数组、嵌套对象)

原因:它们属于引用类型,变量储存的是内存地址(存的是引用),而非实际值

javascript 复制代码
如 arr[0] = 100 或者 obj.name = 'xxx'

这样子直接修改,react不会触发更新;只有拷贝成新引用才会触发更新!

举例如下:

1. 数组拷贝示例
javascript 复制代码
const [list, setList] = useState([1,2,3]);
// 正确:拷贝后更新(生成新引用)
const handleUpdate = () => {
  const newList = [...list]; // 拷贝
  newList[0] = 100;
  setList(newList);
};
// 错误:直接修改,无更新
const handleError = () => {
  list[0] = 100;
  setList(list); // 引用未变,不渲染
};
2. 对象拷贝示例
javascript 复制代码
const [user, setUser] = useState({name:'coco'})
// 正确拷贝
const handleupdate = ()=> {
    cosnt newUser = {...user} // 扩展运算符实现浅拷贝
    newUser.name = 'cocoli'
    setUser(newUser) // 最终更新对象最新数据
}
3. 特殊场景:React.useRef 中的引用类型

如果 ref 存储的是数组 / 对象,修改时虽不触发重渲染,但为了数据一致性,也建议拷贝后更新(避免原数据被意外污染)。

二、无需拷贝的类型(基本数据类型)

  1. 数字、字符串、布尔值、null、undefined等基本数据类型直接赋值即可!

原因:它们存储的是实际值,而非引用;更新直接赋值,react会识别到值的变化,无需拷贝!

javascript 复制代码
const [count, setCount] = useState(0);
const [name, setName] = useState('张三');
// 直接更新,无需拷贝
const handleUpdate = () => {
  setCount(count + 1); // 新值是 1,直接替换
  setName('李四'); // 新值是字符串,直接替换
};
  1. 特殊情况:基本类型的「包装对象」(极少用)

new Number(1)new String('a') 虽为对象,但实际开发中几乎不用,React 中更新逻辑同基本类型。

总结

1. 需要拷贝更新 :数组、对象(含嵌套 / 多维),原因是引用类型需生成新引用让 React 检测到状态变化;

2. 无需拷贝更新 :数字、字符串、布尔值等基本类型,原因是基本类型存储实际值,直接赋值新值就能被 React 识别;

  1. 核心原则:React 靠「引用对比」判断引用类型状态变化,靠「值对比」判断基本类型状态变化。
相关推荐
想吃火锅10052 小时前
【leetcode】405.数字转换为十六进制数js
开发语言·javascript·ecmascript
阿猫的故乡4 小时前
Vue过渡动画从入门到装X:淡入淡出、滑动、列表动画、第三方库全搞定
前端·javascript·vue.js
小和尚敲木头5 小时前
vue3 vite动态拼接图片路径
javascript
我叫黑大帅5 小时前
前端如何竖屏固定视口背景
前端·javascript·面试
不会敲代码16 小时前
我花了三天时间,终于把 Cookie、XSS、CSRF 和浏览器存储给整明白了
javascript·面试
贩卖黄昏的熊6 小时前
flex 布局快速梳理
开发语言·javascript·css3·html5
swipe6 小时前
Mem0 x Agent 实战系列:分层记忆 + 三路召回,搭建真正可用的长期记忆层
前端·javascript·面试
鹤鸣的日常6 小时前
前端运行时动态环境变量方案
前端·react.js·docker·前端框架·vue·gitlab
kyriewen6 小时前
手写 call、apply、bind:从原理到实现,附 3 个最容易忽略的边界情况
前端·javascript·面试
胡萝卜术7 小时前
从内存视角重新认识 JavaScript 数据类型:一份深度学习笔记
前端·javascript·面试