Bootstrap

JS【详解】对象(含对象的存储原理,对象的常用操作,判断对象是否为空对象,对象的深拷贝,对象的创建、遍历、合并、拷贝等)

简介

任何事物都可以看作一个对象,用属性描述它的特征,用方法描述它的行为,如下方代码所示:

let obj = {
  name: "朝阳",
  sayHi: function () {
    console.log("你好!");
  },
};
typeOf obj  // object

变量 obj 被赋值了一个对象,它有属性 name,属性值为 朝阳,方法为 sayHi,具有在控制台打印 你好! 的行为。

JS 内部还定义了很多特殊的对象,如 Function 函数、Array 数组、Date日期、RegExp 正则表达式、Error 报错、Math 数学计算等。

对象的储存原理

对象的值保存在堆内存中,变量 obj 内存储的是对象的引用(对象在堆内存中存储的地址)

常用的对象操作

创建对象

// 创建空对象:自身无任何属性和方法的对象 (因空对象继承自 Object ,所以还具有一些继承来的方法和属性)
let obj1 = {};

// 创建自带属性和方法的对象
let obj2 = {
  // 属性
  name: "朝阳",
  //   方法
  sayHi: function () {
    console.log("你好!");
  },
};

ES6 的简写方式

  • 对象名和属性名相同时,name:name 可简写为 name
  • 方法的 :function 可省略不写
let name = "朝阳";
let obj2 = {
  name,
  sayHi() {
    console.log("你好!");
  },
};

ES6 开始支持动态属性和方法
即用变量作为对象的属性和方法名

let type = "book";
let obj = {
  [type + "Name"]: "《朝阳传》",
  [type + "Sale"]: function () {
    console.log("免费领取啦!");
  },
};

访问属性

// 属性为字符串时,用 . 
obj.name // 得到属性值 '朝阳'

let type = 'hobby'
// 属性为变量时,用 []
obj[type]
  • 访问对象中不存在的属性,返回 undefined

在对象的方法内部访问该对象的属性,可以使用this,此时 this 就是当前对象。

let me = {
  name: '朝阳',
  sayName: function() {
    return this.name;
  }
};

获取对象所有的属性 Object.keys()

let obj = {
    a: 1,
    b: 2
}let keys = Object.keys(obj) // ['a', 'b']

获取对象所有的属性值 Object.values()

let obj = {
    a: 1,
    b: 2
}let values = Object.values(obj) // [1, 2]

添加属性

// 属性为字符串时,用 . 
obj.age = 35

let type = 'hobby'
// 属性为变量时,用 []
obj[type] = '编程'

删除属性

// 属性为字符串时,用 . 
delete obj.age

let type = 'hobby'
// 属性为变量时,用 []
delete obj[type]

遍历对象 for in

for (let key in obj) {
    console.log("属性名:" + key );
    console.log("属性值:" + obj[key ]);
}

合并对象 Object.assign

let a = { gender: "male"}
Object.assign(a, { age: 25 })
console.log(a)  // {"age":25, "gender":"male"}
  • 第一个参数是发起合并的对象
  • 之后的参数是被合并的对象
  • 可以一次合并多个对象
let obj = { a: 1 };
Object.assign(obj, { b: 2 }, { c: 3 });
console.log(obj); // { a: 1, b: 2, c: 3 }
  • Object.assign() 的返回值为合并后的对象
  • Object.assign() 有副作用(会改变原对象)

拷贝对象

浅拷贝

let obj1 = {num:1}
let obj2 = obj1

此时变量 obj2 内存的是对象 {num:1} 的地址,变量 obj1 内存的也是对象 {num:1} 的地址,当变量改变时,obj1 和 obj2 都会改变。

深拷贝
为了避免变量后期改变时,对拷贝后的对象产生影响,经常需要进行深拷贝。

// 简易深拷贝 -- 存在缺陷,但对大部分简单的对象适用
let obj2 = JSON.parse(JSON.stringify(obj1));

更多深拷贝的方法见
https://blog.csdn.net/weixin_41192489/article/details/119633624

【实战】判断变量是否为空对象

if(JSON.stringify(obj)==="{}"){
  // 是空对象
}

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;