JS 深拷贝浅拷贝

一、浅拷贝

cpp 复制代码
// 假设有一个JSON对象
let originalObject = {
  name: "Alice",
  age: 25,
  interests: ["reading", "coding"]
};
 
// 将JSON对象赋值给另一个变量
let copiedObject = originalObject;
 
// 修改新变量的属性
copiedObject.age = 26;
 
// 输出原始对象和新对象的年龄,验证是否为深拷贝
console.log(originalObject.age); // 输出 25
console.log(copiedObject.age);   // 输出 26

二、深拷贝

cpp 复制代码
// 使用JSON.parse(JSON.stringify())创建深拷贝
let deepCopiedObject = JSON.parse(JSON.stringify(originalObject));
 
// 修改新变量的属性
deepCopiedObject.age = 27;
 
// 输出原始对象和新对象的年龄,验证是否为深拷贝
console.log(originalObject.age); // 输出 25
console.log(deepCopiedObject.age); // 输出 27
相关推荐
周聪灬几秒前
iOS的KVO和KVC底层原理
前端
Wect2 分钟前
LeetCode 190. 颠倒二进制位:两种解法详解
前端·算法·typescript
shayu8nian3 分钟前
Agents 在LangChain 中怎么用
前端·人工智能·langchain
codingWhat3 分钟前
你写的是 TypeScript 还是 anyScript ?
前端·typescript
暗不需求5 分钟前
深入 JavaScript 核心:从词法作用域到闭包的底层奥秘
前端·javascript
Jinuss6 分钟前
源码分析之React中的useId
前端·javascript·react.js
牧码岛7 分钟前
Web前端之样式中的prefers-color-scheme,一套完整的主题系统设计与原理解析
前端·css·web·web前端
后海大草鱼7 分钟前
PTE考试谁说RS必须全对?Repeat Sentence提分从0到会就看这篇
前端·后端
前端缘梦9 分钟前
Next.js 实现AI流式输出(打字机效果)
前端·面试·全栈
oscar99910 分钟前
给 Claude Code 装上浏览器:Chrome 集成测试版详解
前端·chrome·集成测试·浏览器