一分钟带你上手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.视图工具...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
安卓文字转语音tts没有声音 安卓文字转语音TTS没有声音的问题在应用中比较常见,通常是由于一些设置或者代码逻辑问题导致的。本文将...
APK正在安装,但应用程序列表... 这个问题可能是由于以下原因导致的:应用程序安装的APK文件可能存在问题。设备上已经存在同名的应用程序...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
报告实验.pdfbase.tt... 这个错误通常是由于找不到字体文件或者文件路径不正确导致的。以下是一些解决方法:确认字体文件是否存在:...