JS之对象
每个对象的属性有两种,每种属性有4中特征描述符
1.数据属性
1.1 [[configurable]]:表示不能通过delete删除属性,不能修改属性的特性,不能将数据属性改为访问器属性,默认值false
<script>
var person = {
name:"pmx"
}
Object.defineProperty(person,"name",{
configurable:false
});
console.log(person.name); //pmx
delete person.name;
console.log(person.name); //pmx
</script>
打印出:
pmx
pmx
<script>
var person = {
name:"pmx"
}
Object.defineProperty(person,"name",{
configurable:false
});
Object.defineProperty(person,"name",{
configurable:true
});
</script>
报错:can not redefine property :name
<script>
var person = {
name:"pmx"
}
Object.defineProperty(person,"name",{
configurable:false
});
Object.defineProperty(person,"name",{
enumerable:false
});
</script>
报错:can not redefine property :name
<script>
var person = {
name:"pmx"
}
Object.defineProperty(person,"name",{
configurable:false
});
Object.defineProperty(person,"name",{
enumerable:true
});
for(var key in person){
console.log(key+":"+person[key]);
}
</script>
打印出:name:pmx
<script>
var person = {
name:"pmx"
}
Object.defineProperty(person,"name",{
configurable:false,
enumerable:false
});
for(var key in person){
console.log(key+":"+person[key]);
}
</script>
没有打印,但也没有报错
<script>
var person = {
name:"pmx"
}
Object.defineProperty(person,"name",{
configurable:false
});
Object.defineProperty(person,"name",{
writable:false
});
person.name = "pan";
console.log(person.name);
</script>
打印出:pan
<script>
var person = {
name:"pmx"
}
Object.defineProperty(person,"name",{
configurable:false
});
Object.defineProperty(person,"name",{
value:"panpan"
});
console.log(person.name);
</script>
打印出:panpan
<script>
var person = {
name:"pan",
city:"shanghai"
}
Object.defineProperty(person,"name",{
configurable:true
});
Object.defineProperty(person,"name",{
get:function(){
return this.city;
}
});
console.log(person.name);
</script>
打印出:shanghai
<script>
var person = {
name:"pan",
city:"shanghai"
}
Object.defineProperty(person,"name",{
configurable:false
});
Object.defineProperty(person,"name",{
get:function(){
return this.city;
}
});
console.log(person.name);
</script>
报错:TypeError: Cannot redefine property: name
综上:
a.configurable设置为false后,那么当前属性就是不可删除滴,delete无效果
b.有两种方式创建对象。
1.对象字面量法:var obj = {name:"pmx"};
2.构造函数定义法:var obj = new Object();obj.name = "pmx";
这两种方式创建的对象的属性的特征描述分别是:configurable:true,enumerable:true,writable:true,value:pmx
c.configurable设置为false之后,不能再更改configurable和enumerable的值,但是对writable和value没有丝毫影响
d.configurable设置为false之后,不能将数据属性更改为访问器属性
1.2 [[enumerable]]:表示能否通过for-in循环遍历对象属性,默认值false
<script>
var person = {
name:"pan",
city:"shanghai"
}
Object.defineProperty(person,"name",{
enumerable:false
});
for(var key in person){
console.log(key+":"+person[key]);
}
</script>
打印出:city=shanghai
没有name=pan
1.3 [[writable]]:表示能否修改属性的值,默认值false
<script>
var person = {
name:"pan"
}
Object.defineProperty(person,"name",{
writable:false
});
person.name = 'pmx';
console.log(person.name);
</script>
打印出:pan
1.4 [[value]]:包含这个属性的数据值,取数据时,从这里取,写数据时,将值写到这里,默认值undefined
<script>
var person = {
name:"pan"
}
Object.defineProperty(person,"name",{
value:"pmx"
});
console.log(person.name);
</script>
打印出:pmx
2.访问器属性
2.1 [[configurable]]:表示能否通过delete删除属性,更改属性的特性,将访问器属性更改为数据属性,默认值false
<script>
var person = {
_name:"pan"
}
Object.defineProperty(person,"name",{
configurable:false,
get:function(){
return this._name;
}
});
console.log(person.name);//pan
delete person.name;
console.log(person.name);//pan
</script>
打印出:
pmx
pmx
<script>
var person = {
_name:"pan"
}
//使用defineProperty创建的对象属性,默认的configurable:false,enmuerable:false,get:undefined,set:undefined
Object.defineProperty(person,"name",{
configurable:false,
enumerable:true,
get:function(){
return this._name;
}
});
for(var i in person){
console.log(i+":"+person[i]);
}
</script>
打印出:
_name:pan
name:pan
<script>
var person = {
_name:"pan"
}
Object.defineProperty(person,"name",{
configurable:false,
enumerable:true,
get:function(){
return this._name;
}
});
Object.defineProperty(person,"name",{
enumerable:false
});
for(var i in person){
console.log(i+":"+person[i]);
}
</script>
报错:TypeError: Cannot redefine property: name
<script>
var person = {
_name:"pan"
}
Object.defineProperty(person,"name",{
configurable:false,
enumerable:true,
get:function(){
return this._name;
}
});
Object.defineProperty(person,"name",{
set:function(value){
this._name = value;
}
});
person.name = "pmx";
for(var i in person){
console.log(i+":"+person[i]);
}
</script>
报错:TypeError: Cannot redefine property: name
<script>
var person = {
_name:"pan"
}
Object.defineProperty(person,"name",{
configurable:false,
enumerable:true,
get:function(){
return this._name;
}
});
Object.defineProperty(person,"name",{
get:function(){
return "get";
}
});
person.name = "pmx";
for(var i in person){
console.log(i+":"+person[i]);
}
</script>
报错:TypeError: Cannot redefine property: name
<script>
var person = {
_name:"pan"
}
Object.defineProperty(person,"name",{
configurable:false,
enumerable:true,
});
Object.defineProperty(person,"name",{
get:function(){
return this._name;
}
});
</script>
报错:TypeError: Cannot redefine property: name
<script>
var person = {
_name:"pan"
}
Object.defineProperty(person,"name",{
configurable:true,
enumerable:true,
get:function(){
return this._name;
}
});
Object.defineProperty(person,"name",{
enumerable:true,
writable:true,
value:"pmx"
});
for(var i in person){
console.log(i+":"+person[i]);
}
</script>
打印出:
_name:pmx
name:pmx
综上:
a.使用Object.defineProperty()创建的属性的默认特 性,configurable:false,enumerable:false,writable:false,value:undefined,get:undefined,set:undefined
b.configurable:false时,不能更改enumerable,get,set;即使get,set为undefined,也不能重新定义get函数
c.给访问器属性添加writable,value特性,就能将其转换为数据属性
2.2[[enumerable]]:表示能否通过for-in循环遍历对象属性,默认值false
2.3[[get]]:读取属性时调用的函数,默认值undefined
2.4[[set]]:写入属性时调用的函数,默认值undefined
3.为对象定义多个属性
Object.defineProperties()
<script>
var person = {}
Object.defineProperties(person,{
name:{
value:'pmx',
writable:false,
enumerable:true
},
city:{
value:"shanghai",
enumerable:false
},
_year:{
value:2016,
writable:false,
enumerable:false
},
year:{
enumerable:true,
get:function(){
return this._year;
}
}
});
console.log(person.name); //pmx
person.name = "pan";
console.log(person.name); //pmx
for(var key in person){
console.log(key+":"+person[key]); //name:pmx;year:2016
}
</script>
4.读取属性的特性描述
Object.getOwnPropertyDescriptor()
<script>
var person = {}
person.name = "pmx";
var des = Object.getOwnPropertyDescriptor(person,"name");
for(var key in des){
console.log(key+":"+des[key]);
}
</script>
value:pmx
writable:true
enumerable:true
configurable:true
JS之对象的更多相关文章
- js定义对象的几种容易犯的错误
//js定义对象的几种容易犯的错误function Person() { getName = function (){ console.info(1); }; return this;}//Perso ...
- 模仿console自写函数打印js的对象
本以为写个递归函数就可以将js的对象打印出来. 当然第一个想到的估计是JSON.stringify() 这个函数.但这个函数打印到浏览器 显示效果不友好.最友好的显示肯定是 控制台打印咯. 结果尝试打 ...
- js自定义对象
一,概述 在Java语言中,我们可以定义自己的类,并根据这些类创建对象来使用,在Javascript中,我们也可以定义自己的类,例如定义User类.Hashtable类等等. 目前在Javascrip ...
- Atitit 跨平台异常处理(2)--------异常转换 -----java c# js异常对象结构比较and转换
Atitit 跨平台异常处理(2)--------异常转换 -----java c# js异常对象结构比较and转换 { "@type":"java.lang.Runti ...
- js中对象使用
简单记录javascript中对象的使用 一.创建对象 //创建一个空对象 var o={}; //创建一个含有两个属性的对象,x.y var o2={x:12,y:'12',name:'JS'}; ...
- JavaScript学习06 JS事件对象
JavaScript学习06 JS事件对象 事件对象:当事件发生时,浏览器自动建立该对象,并包含该事件的类型.鼠标坐标等. 事件对象的属性:格式:event.属性. 一些说明: event代表事件的状 ...
- [转]JS中对象与字符串的互相转换
原文地址:http://www.cnblogs.com/luminji/p/3617160.html 在使用 JSON2.JS 文件的 JSON.parse(data) 方法时候,碰到了问题: thr ...
- JS中对象与字符串的互相转换
在使用 JSON2.JS 文件的 JSON.parse(data) 方法时候,碰到了问题: throw new SyntaxError('JSON.parse'); 查询资料,大概意思如下: JSON ...
- JS面相对象
一.理解对象: //第一种:基于Object对象 var person = new Object(); person.name = 'My Name'; person.age = ; person.g ...
- 关于js一般对象与标配对象
当一个js函数对象被创建时,Function 构造器产生的函数对象会运行类似这样的一些代码 this.prototype={constructor:this} 新函数被赋予了一个prototype属性 ...
随机推荐
- BZOJ3740 : pku2842 N-dimension Matching N维匹配
做$n$次递推求出$n$维Hash值即可,时间复杂度$O(nk)$. #include<cstdio> #define N 500010 int n,i,j,t,delta,ca,cb,a ...
- div+css定位position详解
div+css定位position详解 1.div+css中的定位position 最主要的两个属性:属性 absolute(绝对定位) relative(相对定位),有他们才造就了div+css布局 ...
- Theano深度学习结构分析
Reference:Theano入门三部曲 http://deeplearning.net/tutorial/logreg.html (Softmax回归) http://deeplearning. ...
- CentOS6.4 增加一个SFTP上传的用户
#创建sftp组 groupadd sftp #创建一个用户dsideal useradd -g sftp -s /bin/false dsideal #设置dsideal用户的密码 passwd d ...
- ACM: 限时训练题解-Street Lamps-贪心-字符串【超水】
Street Lamps Bahosain is walking in a street of N blocks. Each block is either empty or has one la ...
- 洛谷 P1305 新二叉树 Label:字符串的输出总是有惊喜
题目描述 输入一串完全二叉树,用遍历前序打出. 输入输出格式 输入格式: 第一行为二叉树的节点数n. 后面n行,每一个字母为节点,后两个字母分别为其左右儿子. 空节点用*表示 输出格式: 前序排列的完 ...
- 【BZOJ】2675: Bomb
题意: 给n个点,任选其中3个点(一个点只能取一次),求选出三个点的最大曼哈顿距离之和与最小曼哈顿距离之和(n<=10^5). 题解: 最大曼哈顿距离之和很好求,就是能包围所有点的经过三个点的矩 ...
- POJ 1141 Brackets Sequence(DP)
题目链接 很早 很早之前就看过的一题,今天终于A了.状态转移,还算好想,输出路径有些麻烦,搞了一个标记数组的,感觉不大对,一直wa,看到别人有写直接输出的..二了,直接输出就过了.. #include ...
- nodeJS中exports和mopdule.exports的区别
每一个node.js执行文件,都自动创建一个module对象,同时,module对象会创建一个叫exports的属性,初始化的值是 {} module.exports = {}; Node.js为了方 ...
- CF #371 (Div. 2) C、map标记
1.CF #371 (Div. 2) C. Sonya and Queries map应用,也可用trie 2.总结:一开始直接用数组遍历,果断T了一发 题意:t个数,奇变1,偶变0,然后与问的 ...