ECMA5规定了只有内部才有的特性,描述了属性的各种特征,这些特性用于实现JavaScript引擎,因此在Js中不能直接访问他们。为了标识特性,我们一般会他们放入两对方括号中。

ECMAScript中有两种属性:数据属性、访问器属性,其中访问器属性不能直接定义,而是通过Object.defineProperty()方法来定义创建,下面会讲这种方法。

需要修改属性默认的特性,则要用到Object.defineProperty()方法了。

Object.defineProperty(属性所在对象,属性名字,描述符对象):其中描述符对象的属性包括configurable、enumerable、writable、value,可修改其中的一或多个属性来修改对应的特性值。

此方法在IE8中只能在DOM对象上使用,而且只能创建访问器属性。(部分实现)

完全实现这个方法的浏览器有:IE9+、Firefox 4+、Safari 5+、Opera 12+、Chrome。

*configurable、enumerable、writable这三个属性若不指定,则默认为false。

var person={};
Object.defineProperty(person,'name',{
value:'a'
});
delete person.name;
alert(person.name);//a var person2={};
Object.defineProperty(person2,'name',{
configurable:true,
value:'a'
});
delete person2.name;
alert(person2.name);//undefined

若将configurable设置为false之后,再设置它为true是无效的。一旦把属性定义为不可配置的,就不能再把它变回可配置的了。

其他两个属性的使用如下:

var person={};
Object.defineProperty(person,'name',{
writable:false,
value:'a'
});
alert(person.name);//a
person.name='b';
alert(person.name);//a
Object.defineProperty(person,'name',{
enumerable:false
});
for(var prop in person){
alert(prop);//不显示
}

访问器属性的常见使用方式:设置一个属性的值导致其他属性发生变化:

var book={
_year:2004,//_标记着只能通过对象方法访问的属性
edition:1
};
Object.defineProperty(book,'year',{
get:function(){
return this._year;
},
set:function(newVal){
if(newVal>2004){
this._year=newVal;
this.edition+=newVal-2004;
}
}
});
book.year=2005;
alert(book.edition);//

除了Object.defineProperty()方法还有Object.defineProperties()方法可以定义多个属性,语法如下:

Object.defineProperties(属性所在对象,{属性1:{描述符对象},{属性2:{描述符对象}}......})

那么要如何获取属性的描述符呢?

Object.getOwnPropertyDescriptor()方法就能做到,语法如下:

Object.getOwnPropertyDescriptor(属性所在的对象,要读取其描述符的属性名称):返回描述符对象。

var person={};
Object.defineProperty(person,'name',{
writable:false,
value:'a' });
var discriptor=Object.getOwnPropertyDescriptor(person,'name');
alert(discriptor.writable);//false
alert(discriptor.value);//'a'

原型对象.isPrototypeOf(实例对象):判断实例对象的原型是不是这个原型对象

Object.getPrototypeOf(实例对象):根据实例对象获得原型对象

function Person(){
}
Person.prototype.name='a';
Person.prototype.sayName=function(){
alert(this.name);
}
var p1=new Person();
var p2=new Object();
alert(Person.prototype.isPrototypeOf(p1));//true
alert(Person.prototype.isPrototypeOf(p2));//false
alert(Object.getPrototypeOf(p1));//Object object(Person也是Object,所以会返回Object)
alert(Object.getPrototypeOf(p2));//Object object
alert(Object.getPrototypeOf(p1)==Person.prototype);//true
alert(Object.getPrototypeOf(p1).name);//'a'
alert(Object.getPrototypeOf(p2)==Person.prototype);//false

实例对象.hasOwnProperty(属性):检测一个属性是存在于实例中,还是存在于原型中。若存在于实例中,则返回true。

function Person(){
}
Person.prototype.name='a';
Person.prototype.sayName=function(){
alert(this.name);
}
var p1=new Person();
var p2=new Person();
p2.name='b';
alert(p1.hasOwnProperty('name'));//false
alert(p2.hasOwnProperty('name'));//true

但是上面的方法若是遇到不存在于原型对象也不存在于实例对象中的属性也返回false,这样就不好判断是不是存在于原型对象中,所以就要用到In操作符了。

in操作符:在通过对象能访问给定属性时返回true,无论在实例对象还是原型对象中。

结合in操作符,我们可以定义一个检测属性位于实例对象还是原型对象中的方法:

function Person(){
}
Person.prototype.name='a';
Person.prototype.sayName=function(){
alert(this.name);
}
var p1=new Person();
var p2=new Person();
p2.name='b';
alert(hasPrototypeProperty(p1,'name'));//true
alert(hasPrototypeProperty(p2,'name'));//false function hasPrototypeProperty(obj,attr){
return !obj.hasOwnProperty(attr)&&(attr in obj);
}

Object.keys(对象):返回一个包含所有可枚举属性的字符串数组。

Object.getOwnPropertyNames(对象):返回所有属性,包括了不可枚举的属性。

function Person(){
}
Person.prototype.name='a';
Person.prototype.sayName=function(){
alert(this.name);
}
alert(Object.keys(Person.prototype));//name,sayName
alert(Object.getOwnPropertyNames(Person.prototype));//constructor,name,sayName

*注:constructor和prototype属性的[[Enumerable]]默认为false。

支持这两个方法的浏览器:IE 9+、Firefox 4+、Safari 5+、Opera 12+、Chrome。

ECMA5中定义的对象属性特性和方法的更多相关文章

  1. Spring中使用事务搭建转账环境方法二 相对简便的注解方法 ——配置文件注入对象属性需要setter方法 注解方法,不需要生成setter方法

    XML配置文件代码如下: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns=" ...

  2. vue2.x版本中Object.defineProperty对象属性监听和关联

    前言 在vue2.x版本官方文档中 深入响应式原理 https://cn.vuejs.org/v2/guide/reactivity.html一文的解释当中,Object.defineProperty ...

  3. CorelDRAW中如何复制对象属性详解

    复制对象属性是一种比较特殊.重要的复制方法,它可以方便而快捷地将指定对象中的轮廓笔.轮廓色.填充和文本属性通过复制的方法应用到所选对象中.本教程将详解CorelDRAW中如何复制对象属性. Corel ...

  4. 继承的基本概念: (1)Java不支持多继承,也就是说子类至多只能有一个父类。 (2)子类继承了其父类中不是私有的成员变量和成员方法,作为自己的成员变量和方法。 (3)子类中定义的成员变量和父类中定义的成员变量相同时,则父类中的成员变量不能被继承。 (4)子类中定义的成员方法,并且这个方法的名字返回类型,以及参数个数和类型与父类的某个成员方法完全相同,则父类的成员方法不能被继承。 分析以上程

    继承的基本概念: (1)Java不支持多继承,也就是说子类至多只能有一个父类. (2)子类继承了其父类中不是私有的成员变量和成员方法,作为自己的成员变量和方法.(3)子类中定义的成员变量和父类中定义的 ...

  5. js 中对象属性特性的描述

    如何自定义属性的特性? 用对象.属性的特性和自定义的属性的特性有什么区别? 它的四大特性 writable   enumerable   configable   有什么区别? 先预习一个用对象.属性 ...

  6. VB 中定义FileSystemObject对象,要先添加对象

     存取文件的方法有很多种,可以使用上述VB提供的函数,使用Windows API函数等等,但是最简单的方法是使用FileSystemObject对象. 1.使用FileSystemObject对象 F ...

  7. javascript中的array对象属性及方法

    Array 对象 Array 对象用于在单个的变量中存储多个值. 创建 Array 对象的语法: new Array(); new Array(size); new Array(element0, e ...

  8. javascript中的style只能取到在HTML中定义的css属性

    如果在css中定义的 li{ width:100px; left:100px; top:; position:absolute; font-style:normal; } 这样执行: oli[0].s ...

  9. JS中delete删除对象属性

    1.删除对象属性 function fun(){   this.name = 'mm';   }   var obj = new fun();   console.log(obj.name);//mm ...

随机推荐

  1. 第04项目:淘淘商城(SpringMVC+Spring+Mybatis)【第十一天】(购物车+订单)

    https://pan.baidu.com/s/1bptYGAb#list/path=%2F&parentPath=%2Fsharelink389619878-229862621083040 ...

  2. Django框架的前奏(安装及介绍)

    几个重要的概念: web的本质: 浏览器中输入网址敲回车发生了几件事? 1.浏览器向服务端发送请求 2.服务端接收请求 3.服务端返回相应的响应 4.浏览器接收响应  根据特定的规则渲染页面展示给用户 ...

  3. Canal —— 基本概念及使用

    参考文档 开源数据同步神器--canal [若泽大数据]大数据之实时数据源同步中间件--生产上Canal与Maxwell颠峰对决

  4. Error running Tomcat8: Address localhost:1099 is already in use(IDEA错误)

    Error running Tomcat8: Address localhost:1099 is already in use(IDEA错误) 有时候运行web项目的时候会遇到 Error runni ...

  5. django,inspectdb,操作已经存在的表

    1.Django附带了一个名为inspectdb程序,它可以通过现有数据库来创建模型,并将相关模型代码另存到指定文件中.在新建的newmodels.py文件中挑选指定表格对应的模型代码,并将其复制到相 ...

  6. mybatis处理LIKE模糊查询字符串拼接

    -- 最佳实践 <select id="getSealByMap" parameterType="map" resultType="map&qu ...

  7. @Transactional回滚问题(try catch、嵌套)

    Spring 事务注解 @Transactional 本来可以保证原子性,如果事务内有报错的话,整个事务可以保证回滚,但是加上try catch或者事务嵌套,可能会导致事务回滚失败.测试一波. 准备 ...

  8. iOS火焰动画效果、图文混排框架、StackView效果、偏好设置、底部手势等源码

    iOS精选源码 高性能图文混排框架,构架顺滑的iOS应用. 使用OpenGLE覆盖阿尔法通道视频动画播放器视图. 可选最大日期截至当日日期的日期轮选器ChooseDatePicker 简单轻量的图片浏 ...

  9. 机器学习算法之——KNN、Kmeans

    一.Kmeans算法 kmeans算法又名k均值算法.其算法思想大致为:先从样本集中随机选取 kk 个样本作为簇中心,并计算所有样本与这 kk 个“簇中心”的距离,对于每一个样本,将其划分到与其距离最 ...

  10. java第二节课 java语法基础动手动脑

    动手动脑1:枚举变量   运行EnumTest.java package test2; public class EnumTest {  public static void main(String[ ...