深入了解Js中的对象
在JavaScript中,对象是个无序的键值对数据集。例如:
var xiaoqiang={
name:"wangqiang",
age:30,
city:"guangzhou",
job:"engineer"
}
上述例子中的小强是一位年轻人,对于这个对象我们用一个括号进行定义。在括号体内我们描述了这个人的几种属性:姓名、年龄、所在城市,工作等。 每一个属性对应一个值,形成了一个数据集。
对象属性的访问、添加、删除
我们可以通过点操作符访问一个对象的属性,访问小强的姓名可以用xiaoqiang.name,也可以用方括号的方式xiaoqiang["name"]的方式。还可以动态添加一个属性, 动态删除一个属性。例如:
xiaoqiang["name"]; //返回wangqiang
xiaoqiang.name; //返回wangqiang
xiaoqiang.height; //undefined
xiaoqiang.height = 1.8 // 给xiaoqiang动态添加了一个属性
delete xiaoqiang.height;
我们还可以通过Object的静态方法defineProperty动态地给一个对象添加属性。下面的例子,我们动态地给xiaoli对象添加一个name属性:
xiaoli = {};
Object.defineProperty(xiaoli,"name",{
value:"xiaoli",
writable:false, // 属性不能修改,
enumerable:true, // 属性可枚举,如:可以通过for ( let item of Object.entries(xiaoli)){...} 的方式枚举属性
})
对象属性的测试
通过in关键字测试对象中的属性,也可以通过Object的hasOwn方法测试对象属性。一个对象的属性包括自有属性和继承来的属性。
"name" in xiaoqiang; //true;
"toString" in xiaoqiang; //true 通过object对象继承的属性
xiaoqiang.hasOwnProperty("age") //true age是xiaoqiang自己的属性
xiaoqiang.hasOwnProperty("toString")//false 通过继承自object的属性,不算自己的属性
Object.hasOwn(xiaoqiang,"age"); //true Object的静态方法判断是否是自己的属性
Object.hasOwn(xiaoqiang,"toString"); //false
Object.getOwnPropertyNames(person); //获取所有自身的属性名称
特殊情况
在定义一个对象时,对象属性的键是字符串类型,一般情况下可以省略单引号或双引号。如果键中包含特殊的字符,那就必须带上双引号或单引号,例如:
var xiaoqiang={
name:"wangqiang",
age:30,
city:"guangzhou",
job:"engineer",
"company-address":"tianhe district,guangzhou" // company-address要加引号
}
xiaoqiang["company-address"]
上述对象xiaoqiang的company-address属性带有特殊的符号,所以定义的时候需用引号包裹起来,在进行属性访问的时候需用方括号
对象属性以及值的遍历
使用Object的entries方法,然后进行遍历
var xiaoqiang={
name:"wangqiang",
age:30,
city:"guangzhou",
job:"engineer",
"company-address":"tianhe district,guangzhou" // company-address要加引号
}
//对象属性的遍历。
for (let item of Object.entries(xiaoqiang)){
console.log(item[0],item[1]);
}
使用Object的keys方法和values方法,然后进行遍历
var xiaoqiang={
name:"wangqiang",
age:30,
city:"guangzhou",
job:"engineer",
"company-address":"tianhe district,guangzhou" // company-address要加引号
}
//对象键的遍历。
for (let item of Object.keys(xiaoqiang)){
console.log(item);
}
//对象值的遍历。
for (let item of Object.values(xiaoqiang)){
console.log(item);
}
对象的冻结、密封、不可扩展
冻结对象:一个冻结对象是指已经不能添加新属性、删除现有属性或修改已有属性的值的对象。使用 Object.freeze() 方法可以将对象转换为冻结对象。
var lihong={};
lihong.name="lihong";
lihong.age=20;
Object.freeze(lihong);
lihong.height = 171; //height属性添加不成功
delete lihong.age; //age属性删除不成功
lihong.name = "Lihong"; //age属性修改不成功
密封对象:一个密封对象是指已经不能添加新属性和删除现有属性的对象,但是可以修改已有属性的值。使用 Object.seal() 方法可以将对象转换为密封对象。
var lihong={};
lihong.name="lihong";
lihong.age=20;
Object.seal(lihong);
lihong.height = 171; //height属性添加不成功
delete lihong.age; //age属性删除不成功
lihong.name = "Lihong"; //name属性可修改的
不可扩展对象:一个不可扩展对象是指已经不能添加新属性的对象,但是可以修改现有属性的值或删除现有属性。使用 Object.preventExtensions() 方法可以将对象转换为不可扩展对象。
var lihong={};
lihong.name="lihong";
lihong.age=20;
Object.preventExtensions(lihong);
lihong.height = 171; //height属性添加不成功
delete lihong.age; //age属性是可删除的
lihong.name = "Lihong"; //name属性是可修改的
文章同时发表在:码农编程网 欢迎访问
本节重点
- 对象是一个无序键值对的数据集;
- 对象的属性必须是字符串、如包含特殊的字符引号包裹起来;
- 对象属性的添加、测试、对象属性和值的遍历;
- 冻结对象、密封对象、不可扩展对象。
深入了解Js中的对象的更多相关文章
- js中判断对象具体类型
大家可能知道js中判断对象类型可以用typeof来判断.看下面的情况 <script> alert(typeof 1);//number alert(typeof "2" ...
- 浅解析js中的对象
浅解析js中的对象 原文网址:http://www.cnblogs.com/foodoir/p/5971686.html,转载请注明出处. 前面的话: 说到对象,我首先想到的是每到过年过节见长辈的时候 ...
- js中XMLHttpRequest对象实现GET、POST异步传输
js中XMLHttpRequest对象实现GET.POST异步传输 /* * 统一XHR接口 */ function createXHR() { // IE7+,Firefox, Opera, Chr ...
- JavaScript学习12 JS中定义对象的几种方式
JavaScript学习12 JS中定义对象的几种方式 JavaScript中没有类的概念,只有对象. 在JavaScript中定义对象可以采用以下几种方式: 1.基于已有对象扩充其属性和方法 2.工 ...
- js中推断对象详细类型
大家可能知道js中推断对象类型能够用typeof来推断. 看以下的情况 <script> alert(typeof 1);//number alert(typeof "2&quo ...
- JavaScript学习12 JS中定义对象的几种方式【转】
avaScript学习12 JS中定义对象的几种方式 转自: http://www.cnblogs.com/mengdd/p/3697255.html JavaScript中没有类的概念,只有对象. ...
- JS中有关对象的继承以及实例化、浅拷贝深拷贝的奥秘
一.属性的归属问题 JS对象中定义的属性和方法如果不是挂在原型链上的方法和属性(直接通过如类似x的方式进行定义)都只是在该对象上,对原型链上的没有影响.对于所有实例共用的方法可直接定义在原型链上这样实 ...
- JS中定义对象和集合
在js中定义对象: 方式一: var obj = {}; obj['a']=1; obj['b']=2; 方式二: var obj=new Object(); obj.a=1; obj.b=2; 在j ...
- Js中Map对象的使用
Js中Map对象的使用 1.定义 键/值对的集合. 2.语法 mapObj = new Map() 3.备注 集合中的键和值可以是任何类型.如果使用现有密钥向集合添加值,则新值会替换旧值. 4.属性 ...
- JS中的对象和方法简单剖析
众所周知,在js中对象就是精髓,不理解对象就是不理解js. 那么什么事js中的对象呢? 在js中,几乎一切皆对象: Boolean ,String,Number可以是对象(或者说原生数据被认作对象): ...
随机推荐
- 自用nodejs安装笔记
下载Nodejs 进入Nodejs官网https://nodejs.org/zh-cn/ 下载 安装Node.js 检查Nodejs和npm包管理器是否安装成功 用管理员打开cmd控制台 命令行输入n ...
- 一招教你 Notion 文章导出到公众号
Notion是一个功能强大的笔记应用程序,有许多优点,包括: 用户友好的界面 跨平台支持 可以结构化组织笔记 多人协作 可以添加多种类型的媒体文件 可以添加评论和任务 这些优点使Notion成为一个广 ...
- redo log的用处
redo log用途 1. 用途 保证数据的更新操作不丢失,同时保证了性能 2. 如何没有redo log,如何保证数据库的更新操作不会由于数据库的宕机而丢失? 对数据库进行修改,应该是先从磁盘读取数 ...
- 【LeetCode贪心#12】图解监控二叉树(正宗hard题,涉及贪心分析、二叉树遍历以及状态转移)
监控二叉树 力扣题目链接(opens new window) 给定一个二叉树,我们在树的节点上安装摄像头. 节点上的每个摄影头都可以监视其父对象.自身及其直接子对象. 计算监控树的所有节点所需的最小摄 ...
- Java面试——搜索
更多内容,前往 IT-BLOG 一.Elasticsearch了解多少 ElasticSearch 是一个基于 Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于 RESTfu ...
- Java面试——Nginx
一. 二.Nginx 的优点 [1]速度更快:这表现在两个方面:一方面,在正常情况下,单次请求会得到更快的响应:另一方面,在高峰期(如有数以万计的并发请求),Nginx 可以比其他 Web服务器更快地 ...
- 详解DDD:如何避免写流水账代码?
在日常工作中我观察到,面对老系统重构和迁移场景,有大量代码属于流水账代码,通常能看到开发在对外的API接口里直接写业务逻辑代码,或者在一个服务里大量的堆接口,导致业务逻辑实际无法收敛,接口复用性比较差 ...
- 常用ADB命令使用方法
移动端操作流程 在设置中找到关于手机(或关于平板电脑) 连续点击版本号5次 在系统和更新中点击开发者选项 打开USB调试功能 PC端操作流程 打开cmd或powershell 移动到adb.exe所在 ...
- Java 内存模型(二)
Java 内存模型(二) happens-before JSR-133 提出了 happens-before 的概念,通过这个概念来阐述操作之间的内存可见性.如果一个操作执行的结果需要对另一个操作 ...
- Wiki.js配置LDAP认证
安装好wikijs 之后, 可以进行进一步的详细配置. 这里介绍 LDAP 认证的配置. 在 管理 -> 身份验证 -> 添加策略 -> 选择 LDAP/AD , 如下: 接下来进行 ...