前端数据拷贝(浅拷贝、深拷贝)

浅拷贝

1 直接赋值

2 扩展运算符(...)

3 abject.assign()

Object.assign({}, obj);

4 slice和concat

slice 截取数组

concat 拼接数组

深拷贝

1 JSON.parse(JSON.stringify(待拷贝对象))

2 使用第三方库 Lodash

javascript 复制代码
const _ = require('lodash');

let obj = {
    name: 'demo',
    age: 26
}

let obj2 = _.cloneDeep(obj);
obj2.name = "demo_new";

console.log(obj); // {name: "demo", age: 26}
console.log(obj2); // {name: "demo_new", age: 26}

3 手写一个深拷贝

javascript 复制代码
function deepClone (obj) {
    if (typeof obj !== 'object' || obj == null) {
        return obj;
    }
    
    let deepCloneObj = Array.isArray(obj) ? [] : {}
    
    for (let key in obj) {
        if (obj.hasOwnProperty(key)) {
            deepCloneObj[key] = deepClone(obj[key]);
        }
    }
    
    return deepCloneObj;
}
相关推荐
祈澈菇凉几秒前
如何使用useContext进行全局状态管理?
前端·javascript·react.js
澄江静如练_1 小时前
vue3中的标签属性中的Ref
前端·javascript·vue.js
GIS好难学1 小时前
考研出分24小时,人类精神状态图鉴
前端·考研·gis·gis开发·webgis·地信
斯~内克1 小时前
React Router 完全指南:从基础到高级实践
前端·react.js·前端框架
m0_748232392 小时前
qwenvl 以及qwenvl 2 模型架构理解
android·前端·后端
冲!!2 小时前
vue3中ref和reactive响应式数据、ref模板引用(组合式和选项式区别)、组件ref的使用
前端·javascript·vue.js
匹马夕阳2 小时前
React vs Vue3深度对比与使用场景分析
前端·react.js·前端框架
浪遏2 小时前
2025年2月凉面与热面(2)—— 还没开始就结束了🤡?
前端·面试
七灵微2 小时前
【前端】简单原生实例合集html,css,js
前端·css·html
祈澈菇凉2 小时前
2025年React Hooks的进阶面试题130题及其答案解析..
前端·react.js·前端框架