在新的js规范中,我们又多了几种定义属性的方法。给一个对象添加属性,以前可能是这样的

var o = {name: '未起名';}

现在可以这样子

var o = {get name(){return '终生不改名'}}

o.name // 终生不改名

o.name = '换个名字';

o.name // 终生不改名;没法改变其值

还可以是这样子的

var o = {};
Object.defineProperty(o, name, {
value: '数据属性',
writable: true
})
// witable表示该属性是否可读写。false只可读,true可读写
o.name = '可修改的属性' o.name // ?

当然还有其他的方式。

以上两种新的写法,第一种添加的属性叫做存储器属性(getter&setter),第二种是数据属性(value)。一个【属性描述符】不能同时包含value属性又有setter&getter之一。

【属性描述符】是一个对象,它是描述对象属性的。描述符一般有四个属性,分为存储器属性描述符和数据属性描述符(这个是我自己的分类)

//存储器属性描述符对象
{
get: function(){},
set:function(){},
enumerable:boolean,
configurable:boolean
} //数据属性描述符对象
{
value:'',
writable:boolean,
enumerable:boolean,
configurable:boolean
}

如果没有显式声明某属性,默认是undefined或者false。enumerable表示该属性是否可枚举。像很多内置的对象的属性一样,设为false,则此属性是不可以枚举的(for in循环无法遍

历)。configurable表示是否可配置,如是否可以用delete删除此属性,是否可以修改enumerable或者writable的值。writable是否可写,对于存储器属性,没有该项。其读写操作由get、

set完成。当然,这只是粗略的说明。

存储器属性

var name = '给孩子起个名吧',

person = {
// 读取属性
get childName(){
return name;
},
// 给属性写入值
set childName(newName){
name = newName;
},
// 是否可枚举
enumerable: true,
// 是否可配置
configurable: true
}
// 上面这几行代码近似于下面的效果 /*
var person = {childName: name};
*/
/*这种写法需要借助第三个变量或者属性来完成。因为在get和set使用【this.该属性】会造成无限递归,无法在set中无法给
该属性赋值,也无法在get中返回。要么借助第三者(get&set),要么返回常量(get)
*/
//一个可以读取,但不允许改变的值.例如产品的ID号,一旦生产,则不允许再修改
var product = {get pID(){return '113230'}}
product.pID = '231234' //1.0。企图改变pID的值是徒劳的

数据属性

/* 数据属性不能像存储器属性那样直接在对象内部声明,不然会变成普通属性。
需要借助defineProperty来完成*/
var o = {};
//defineProperty接受三个参数,对象,对象的属性名,属性描述符(也是对象)
Object.defineProperty(o,'name',{
value: '这是数据属性',//这个值也可以是个函数,调用:o.name()
writable: true,
enumerable: true,
configurable: true
}); o.name // 这是数据属性 //存储器属性也可以用这种方式(添加多个属性用defineProperties),给一个矩形rect添加三个属性,w,h,area var rect = {};
Object.defineProperties(rect, {
w:{value:10,writable:true},
h:{value:15,writable:true},
area: {
get: function(){
return this.w*this.h;
},
set: function(newVal){
var rat = newVal/this.area;
this.w *= rat;
this.h *= rat;
}
}
});

rect.area // 150
rect.area *= 2;
//改变面积的值,间接改变长和宽
rect.w // 20
rect.h // 30

总结:利用这些API可以实现很多意想不到的功能,除了保持对象属性不变,可以监听属性变化、读取(类似日志),还能像内置对象的属性一样,扩展得方法也能不被枚举出来。

更多相关阅读或者这里

javascript存储器属性与数据属性的更多相关文章

  1. javascript对象属性——数据属性和访问器属性

    ECMA-262第五版在定义时,描述了属性property的各种特征,定义这些特性是为了实现javascript引擎用的,为了表示该特性是内部值,规范把它们放在了两对儿方括号中,例如[[Enumera ...

  2. JavaScript对象的两类属性(数据属性与访问器属性)

    对JavaScript来说,属性并非只是简单的名称和值,JavaScript用一组特征(attribute)来描述属性 (property). 第一类属性数据属性具有四个特征. value:就是属性的 ...

  3. javascript 查找属性的过程

     当执行 一个对象赋值操作的时候  js引擎会怎样处理呢??? 例如  有个foo对象  ,要进行这个操作 foo.a=2 1, 首先会在foo对象中查找,如果不存在a属性,就会去原型链上面找,如果原 ...

  4. ECMAScript中有两种属性:数据属性和访问器属性。

    ECMA-262定义这些特性是为了实现JavaScript引擎用的,因此在JavaScript中不能直接访问它们.为了表示特性是内部值,该规范把它们放在了两对儿方括号中,例如 [[Enumerable ...

  5. JavaScript document属性和方法

    JavaScript document属性和方法 --------------------------------------------属性: 1. Attributes     存储节点的属性列表 ...

  6. JavaScript 全局属性/函数

    JavaScript 全局 JavaScript 全局属性和方法可用于创建Javascript对象. JavaScript 全局属性 属性 描述 Infinity 代表正的无穷大的数值. NaN 指示 ...

  7. 删除要被替换的元素的所有事件处理 程序和 JavaScript 对象属性

    使用本节介绍的方法替换子节点可能会导致浏览器的内存占用问题,尤其是在 IE 中,问题更加明显.在删除带有事件处理程序或引用了其他 JavaScript 对象子树时,就有可能导致内存占用问题.假设 某个 ...

  8. Javascript对象属性与方法汇总

    Javascript对象属性与方法汇总 发布时间:2015-03-06 编辑:www.jquerycn.cn 详细介绍下,javascript对象属性与对象方法的相关知识,包括javascript字符 ...

  9. javascript 节点属性详解

    javascript 节点属性详解 根据 DOM,html 文档中的每个成分都是一个节点 DOM 是这样规定的:整个文档是一个文档节点每个 html 标签是一个元素节点包含在于 html 元素中的文本 ...

随机推荐

  1. IDEA java开发 Restful 风格的WebService

    官网:https://www.jetbrains.com/help/idea/restful-webservices.html 1.在IntelliJ中创建新项目,选择Java Enterprise ...

  2. scala类型系统 type关键字

    和c里的type有点像. scala里的类型,除了在定义class,trait,object时会产生类型,还可以通过type关键字来声明类型. type相当于声明一个类型别名: scala> t ...

  3. Maven中的SNAPSHOT版本和正式版本理解

    Maven中建立的依赖管理方式基本已成为Java语言依赖管理的事实标准,Maven的替代者Gradle也基本沿用了Maven的依赖管理机制.在Maven依赖管理中,唯一标识一个依赖项是由该依赖项的三个 ...

  4. 浅记初次使用expect、scp中出现的一些小问题

    以前也学过一些shell,不过学得并不是很深入,动手写的代码的时间也不是很多.前不久将shell比较细的过了一遍,leader布置了任务让用shell写一个脚本将redis源码压缩包从一个服务器上传到 ...

  5. Android,TextView的所有属性和方法

    XML 属性 属性名称 相关方法 描述 android:autoLink setAutoLinkMask(int) 设置是否当文本为URL链接/email/电话号码/map时,文本显示为可点击的链接. ...

  6. Solidworks如何添加齿轮

    打开ToolBox,找到GB,动力传动,齿轮,正齿轮,然后拖放到绘图窗口(切记要在装配图里面弄,不是在单个零件里面弄)   设置齿轮的参数,一般只需要设置模数,齿数,面宽,类型,总长度(面宽就是有齿轮 ...

  7. Tomcat的server.xml配置讲解(一)

    一.Tomcat虚拟目录的配置 1.服务器配置 默认端口号为8080,如果要想修改端口号,则可以在Tomcat目录中的conf/server.xml文件,找到如下代码,将端口号改为:80:保存serv ...

  8. 重构wm_concat,采用clob做为存储容器

    --Type CREATE OR REPLACE TYPE zh_concat_im AUTHID CURRENT_USER AS OBJECT ( CURR_STR clob, STATIC FUN ...

  9. jQuery-mobile 学习笔记之三(事件监听)

    续上 触摸事件 - 当用户触摸屏幕时触发(敲击和滑动) 滚动事件 - 当上下滚动时触发 方向事件 - 当设备垂直或水平旋转时触发 页面事件 - 当页面被显示.隐藏.创建.载入以及/或卸载时触发 一.初 ...

  10. struts2配置默认Action

    作用:当一个请求无法匹配到任何一个struts的action时,可以配置一个默认Action 例如:当请求路径不正确时,跳转到一个404.jsp页面 <package extends=" ...