js中批量修改对象属性

简介: js中批量修改对象属性

首先,有这个对象

let a = {
    id: 1,
    name: '张三',
    age: 18,
    sex: 0
}

需求:同时修改name,id,并添加一个新属性c

常规写法:

 

a.id = 2;
a.name = '李四';
a.c = 1;

方法1:使用Object.assign()

Object.assign()常用来拷贝合并对象,相同属性替换,不同属性新增

写法:

 

a = Object.assign(a,{id:2,name:'李四',c:1})

方法2:使用Object.defineProperties()

Object.defineProperties(object,descriptors)参数说明如下:

object:对其添加或修改属性的对象,可以是本地对象或 DOM 对象。
descriptors:包含一个或多个描述符对象,每个描述符对象描述一个数据属性或访问器属性。
Object.defineProperties(a, {
    id: {
        value: 2
    },
    name: {
        value: '李四'
    },
    c:{
        value: 1
    }
})

而且这两种写法也不会使vue的reactive失去响应

相关文章
|
3天前
|
JavaScript 前端开发 安全
安全开发-JS应用&原生开发&JQuery库&Ajax技术&加密编码库&断点调试&逆向分析&元素属性操作
安全开发-JS应用&原生开发&JQuery库&Ajax技术&加密编码库&断点调试&逆向分析&元素属性操作
|
2天前
|
存储 JavaScript 前端开发
第六篇-Javascript对象
第六篇-Javascript对象
9 2
|
4天前
|
JavaScript 前端开发
JavaScript进阶-模板字符串与增强的对象字面量
【6月更文挑战第19天】ES6的模板字符串和增强对象字面量提高了JavaScript的易读性和效率。模板字符串(` `)支持变量嵌入和多行,简化了字符串处理;增强对象字面量允许简写属性与方法,以及动态属性名。注意模板字符串的闭合和性能影响,以及对象字面量的简写语法和计算属性名的恰当使用。通过实例展示了这两项特性的应用,助力编写更优雅的代码。
|
4天前
|
JavaScript
js 判断对象内所有值为空
js 判断对象内所有值为空
|
1天前
|
JavaScript 前端开发
JS如何判断一个对象是否为数组?
JS如何判断一个对象是否为数组?
7 0
|
1天前
|
JavaScript 前端开发
JS遍历数组和对象的常用方法有哪些?
JS遍历数组和对象的常用方法有哪些?
6 0
|
4天前
|
JavaScript 前端开发
js数组包对象格式怎么根据不同的键值使用sort排序一组数组
js数组包对象格式怎么根据不同的键值使用sort排序一组数组
|
4天前
|
移动开发 JavaScript 前端开发
原生js如何获取dom元素的自定义属性
原生js如何获取dom元素的自定义属性
11 0
|
9天前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的校园竞赛管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的校园竞赛管理系统附带文章源码部署视频讲解等
158 63
|
9天前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的小型医院医疗设备管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的小型医院医疗设备管理系统附带文章源码部署视频讲解等
25 6