Javascript中的对象(八)
一、如何编写可以计算的对象的属性名
我们都知道对象的属性访问分两种,键访问(["属性名"])和属性访问(.属性名,遵循标识符的命名规范)
对于动态属性名可以这样
var prefix = "foo"
var obj = {
[prefix +"name"] : "youyi",
[prefix +"age"]: "22"
}
(这里可以对比学习一下es6中的symbol)
二、如何给对象的属性添加特性
通过Object.defineProperty()定义对象的属性
1、writable为false,不可给对象属性a赋值
var obj = {}
Object.defineProperty(obj, "a", {
value: 2,
writable: false,
configurable: true,
enumerable: true
}) console.log(obj.a)//2
obj.a = 3
console.log(obj.a)//2
2、configurable为false,属性不能再定义第二次,定义之后会报错;也不能删除属性。
属性不能再定义第二次,定义之后会报错
var obj = {}
Object.defineProperty(obj, "a", {
value: 2,
writable: false,
configurable: false,
enumerable: true
}) obj.a = 3 Object.defineProperty(obj, "a", {
value: 2,
writable: false,
configurable: true,
enumerable: true
})
不能删除属性
var obj = {
}
obj.a = 3
console.log("normal:", obj.a)
delete obj.a
console.log("normal:",obj.a) Object.defineProperty(obj, "a", {
value: 2,
writable: false,
configurable: false,
enumerable: true
})
console.log(obj.a)
delete obj.a
console.log(obj.a)
输出:
normal: 3
normal: undefined
2
2
3、enumerable为false,属性不会出现在枚举中
什么是可枚举?
对象属性能出现在对象的遍历中就是可枚举。
如何判断属性是否可以枚举?
obj.propertyIsEnumerable("属性名")
如何获取所有可枚举属性?
Object.key(obj)(注意:和getOwnPropertyNames()不同,后者会获取到对象中的所有属性,两者共同点是只查找对象直接包含的属性,不查找原型链上的)
四、创建不可变性的对象
1、writable和configurable都设置为false
2、Object.preventExtensions禁止对象的扩展,不能再添加新的属性
var obj = {}
obj.a = 2
Object.preventExtensions(obj)
obj.b = 3
obj.b//undefined
3、Object.seal()密封对象,调用Object.preventExtensions,并且将所有属性configurable设置为false。(不可添加新属性,也不能重新配置或
删除现有任何属性)
4、Object.freeze()冻结对象,在Obect.seal()的基础上,将所有数据访问属性writable设置为false。(啥都干不了了)
五、对象中的[[Get]]、[[Put]]、Getter和Setter
当给一个对象设置属性时,会触发[[Put]];
当读取一个对象中的属性时,会触发[[Set]]
创建访问属性符(当给属性定义getter、setter或两者都有时):
var obj = {
get a() {
return 2
}
} Object.defineProperty(obj, "b", {
get: function() {
return this.a*2
},
enumerable: true
})
//obj.a //2
//obj.b //4
属性定义get方法时,赋值操作会无效
var obj = {
get a() {
return 2
}
}
obj.a = 3
obj.a //2
六、判断对象属性是否存在
判断对象中是否存在某个属性的两种方式:in和hasOwnProperty,
两者的区别是in会遍历到对象的原型链上,hasOwnProperty只会在对象中查找,不会查找至原型链。
需要注意的是,对于用Object.create(null)创建的空对象和{}不同,前者创建的空对象没有prototype属性
var t = Object.create(null);
t.hasOwnProperty("a")
//Uncaught TypeError: t.hasOwnProperty is not a function var t = {};
t.hasOwnProperty("a")
//false
Javascript中的对象(八)的更多相关文章
- javascript中的对象,原型,原型链和面向对象
一.javascript中的属性.方法 1.首先,关于javascript中的函数/“方法”,说明两点: 1)如果访问的对象属性是一个函数,有些开发者容易认为该函数属于这个对象,因此把“属性访问”叫做 ...
- Javascript 中判断对象为空
发现了一个巧妙的实现: 需要检查一个对象(Object)是否为空,即不包含任何元素.Javascript 中的对象就是一个字典,其中包含了一系列的键值对(Key Value Pair).检查一个对象是 ...
- JavaScript 中的对象
JavaScript 中的对象 在 JavaScript 中,对象是数据(变量),拥有属性和方法. JavaScript 中的所有事物都是对象:字符串.数字.数组.日期,等等. 访问对象的属性 访 ...
- javascript中Date对象的应用——简易日历的实现
× 目录 [1]效果 [2]HTML [3]CSS[4]JS 前面的话 简易日历作为javascript中Date对象的常见应用,用途较广泛.本文将详细说明简易日历的实现思路 效果演示 HTML说明 ...
- JavaScript中判断对象类型方法大全1
我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...
- (转)javascript中的对象查找
本文转自:http://otakustay.com/object-lookup-in-javascript/ ---很棒的一篇文章,作者的其他文章还暂时没读,但相信作者是一个谦虚 谨慎的好工程师 近 ...
- Javascript中的对象和原型(3)
在Javascript中的对象和原型(二)中我们提到,用构造函数创建的对象里面,每个对象之间都是独立的,这样就会降低系统资源的利用率,解决这样问题,我们就要用到下面提到的原型对象. 一 原型对象 原型 ...
- (转)javascript中event对象详解
原文:http://jiajiale.iteye.com/blog/195906 javascript中event对象详解 博客分类: javaScript JavaScriptCS ...
- JavaScript中判断对象类型的种种方法
我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...
- JavaScript中String对象的match()、replace() 配合正则表达式使用
正则表达式由来已久,查找替换功能非常强大,但模板难记复杂. JavaScript中String对象的match().replace()这2个方法都要使用正则表达式的模板.当模板内容与字符串不相匹配时, ...
随机推荐
- iproute2 与 net-tools
https://linux.cn/article-4326-1.html https://blog.csdn.net/astrotycoon/article/details/52317288 如今很多 ...
- <<操作,&0xff以及|的巧妙运用(以POJ3523---The Morning after Halloween(UVa 1601)为例)
<<表示左移,如a<<1表示将a的二进制左移一位,加一个0,&0xff表示取最后8个字节,如a&0xff表示取a表示的二进制中最后8个数字组成一个新的二进制数, ...
- 基于BP的B/S架构破解
思路历程: 1.获取用户名 2.获取密码字典 3.使用BP爆破 案例: 管理人员在平时的网络生活中没有良好的个人信息保护,让不法份子有机可乘.例如WordPress等的类似网站使用PHP开发,虽然功能 ...
- plsql developer 使用sys用户登录,报ORA-01031权限不足,解决sys(dba权限用户)远程登录报错。
数据库服务器架设在机器A上,此时我在机器B上进行远程连接,使用sys账号远程登录时报ORA-01031:insufficient privileges 或 ORA-01017: invalid use ...
- CH4908 Race
题意 4908 Race 0x49「数据结构进阶」练习 描述 给定一棵 N 个节点的树,每条边带有一个权值. 求一条简单路径,路径上各条边的权值和等于K,且路径包含的边的数量最少. 输入格式 第一行两 ...
- gdb入门
下面是我自己写的一个测试用例 a.c #include<stdio.h> int add(int a,int b){ return a+b; } int main(){ int n=add ...
- skipper backend 负载均衡配置
skipper 对于后端是支持负载均衡处理的,支持官方文档并没有提供,实际使用中,这个还是比较重要的 同时支持健康检查. 格式 hello_lb_group: Path("/foo" ...
- Bubble Sort冒泡排序
冒泡排序是一种简单的排序算法. 它每次重复的访问过要排序的数列, 一次比较两个元素, 如果他们的顺错误, 就把他们交换过来. 下面这种图很清晰的解释了什么是冒泡算法. 具体算法描述如下: 1. 比较相 ...
- STM32的ISP下载程序方式:
STM32的板子的串口ISP下载方法:Boot0接到3.3V上,Boot1接到GND,对板子重新上电,STM32单片机重启的时候,会进入到ISP模式.
- java 中 heap(堆)和stack(栈)的区别
总结在Java里面Heap和Stack分别存储数据的不同. 区别项 Heap(堆) Stack(栈) JVM中的功能 内存数据区 内存指令区 存储数据 对象实例(注1) 基本数据类型, 指令代码,常量 ...