一分钟带你上手JS对象的基本用法
创始人
2024-05-09 10:39:20
0

前言

相信大家对 JavaScript 中的对象都不陌生,而且我们几乎每天都在使用它,那你对对象的认识有多少呢?本章就带大家一起出浅入深的了解 JavaScript 中的对象。


一、什么是对象?

到底什么是对象呢?大多数人可能都会脱口而出,一个大括号{}呗。用官方的话来说,在 js 中对象是一组元素的相关属性和方法的集合,所有的事物都是对象,例如:日期,字符串,数字,数组,布尔,函数等。你可以理解为对象就是属性和方法组成的,是一种无序的数据集合,用来描述某个事物的信息。


二、怎么声明对象?

对象的声明其实特别简单,以下为两种常见的声明方式。

1. 直接声明

let obj = {}

2. 通过 new 关键字创建

let obj2 = new Object

当然,声明对象的方式远不止上面两种,还有很多其它的方式,例如通过构造函数、工厂函数、混合模式、原型模式等等,感兴趣的同学可以去了解一下。


三、对象是如何访问内部属性的?

对象.属性
对象['属性']

四、如何遍历对象?

let obj = {id: "001",name: "小欧兰",age: "18",sex: "女",
};
for (let i in obj) {console.log(i); //所有属性名console.log(obj[i]); //所有属性值console.log(`${i}:${obj[i]}`); //所有属性名和属性值
}

五、如何合并多个对象?

1. Object.assign(target,sources) 浅拷贝

第一个值是目标对象,第二个值是源对象,返回值为目标对象。需要注意的是对象中有同名属性会被后面的对象属性值覆盖。

let obj = {id: "001",name: "小欧兰",age: "18",sex: "女",
};
let obj1 = {old: "12",cki: "no",sex: "男",
};
const objs = Object.assign(obj, obj1);
console.log(objs);

控制台打印

在这里插入图片描述


2. 扩展运算符(…)es6

扩展运算符(…)是 ES6 的语法,用于取出参数对象的所有可遍历属性,然后拷贝到当前对象之中。需要注意的是对象中有同名属性会被后面的对象属性值覆盖。

let obj = {id: "001",name: "小欧兰",age: "18",sex: "女",
};
let obj1 = {old: "12",cki: "no",sex: "男",
};
const objs = { ...obj, ...obj1 };
console.log(objs);

控制台打印

在这里插入图片描述


除此之外,你还可以使用 lodash 工具实现对象的合并,感兴趣的同学可以去了解一下。


六、如何将对象所有属性值清空?

Object.keys(this.ruleForm).forEach((key) => (this.ruleForm[key] = "")
);

七、对象中的增删改查?

对象的原始状态

let obj = {id: "001",name: "小欧兰",age: "18",sex: "女",
};

1. 增

obj.site = "北京";
obj["site"] = "北京";

控制台打印

在这里插入图片描述


2. 删

delete obj.name;
delete obj["name"];
// es6 
Reflect.deleteProperty(obj, "name");

控制台打印

在这里插入图片描述


2.1 Reflect.deleteProperty()

Reflect.deleteProperty() 方法允许删除对象上的属性。如果该方法返回 true,则表示删除该属性成功。否则,它返回 false


用法:

Reflect.deleteProperty(target, propertyKey)

参数:

  • target 要删除其属性的目标对象

  • propertyKey 要删除的属性的名称


返回值:

布尔值表示该属性是否已成功删除。


3. 改

obj.id = "002";
obj["id"] = "002";

控制台打印

在这里插入图片描述


修改属性名

let a = JSON.parse(JSON.stringify(obj).replace(/id/g, "code")); //将对象中属性名为 id 的修改成 code

控制台打印

在这里插入图片描述
有关于 replace 方法的详细用法,可访问 JavaScript replace() 方法 查看。


4. 查

查的话直接通过 log 即可。

console.log(obj);

控制台打印

在这里插入图片描述


相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...