前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JS浅拷贝

JS浅拷贝

作者头像
peng_tianyu
发布2022-12-15 18:03:53
8540
发布2022-12-15 18:03:53
举报
文章被收录于专栏:前端开发随记

浅拷贝

浅拷贝创建一个新对象,这个对象仅对原对象的属性进行拷贝,属性值是基本类型时,拷贝的是原数据,属性值是引用类型时,拷贝的是指针

实现浅拷贝的几种方法

  • Object.assign
代码语言:javascript
复制
let person = { name: 'swt', age: 20 }

let people = Object.assign({}, person)

people.name = 'pty'

console.log(person) //  { name: 'swt', age: 20 }
console.log(people) //  { name: 'pty', age: 20 }
  • Array.prototype.concat
代码语言:javascript
复制
let arr = [1, 2, 3]

let newArr = arr.concat()

newArr[0] = 100

console.log(arr) //  [ 1, 2, 3 ]
console.log(newArr) //  [ 100, 2, 3 ]
  • Array.prototype.slice
代码语言:javascript
复制
const animals = ["ant", "bison", "camel", "duck", "elephant"]

const newAnimals = animals.slice();

newAnimals[0] = "chicken"

console.log(animals); //  [ 'ant', 'bison', 'camel', 'duck', 'elephant' ]
console.log(newAnimals); //  [ 'chicken', 'bison', 'camel', 'duck', 'elephant' ]
  • Spread syntax
代码语言:javascript
复制
const a = [1, 2, 3]

const b = [...a]

b[0] = 4

console.log(a); //  [ 1, 2, 3 ]
console.log(b); //  [ 4, 2, 3 ]
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-10-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 浅拷贝
  • 实现浅拷贝的几种方法
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档