js对象—类型和属性特性
前言
权威指南中摘要的,工作中用不到的,重要的js基础。
三类对象两类属性
内置对象(native object) 是由ECMScript规范定义的对象或者类。例如:函数,数组,日期,正则...
宿主对象(host object) 是由js编译器所嵌入的宿主环境(web浏览器)所定义的。比如客户端js中表示网页结构的HTMLElement对象就是宿主环境创建的对象。宿主环境定义的对象可以直接使用的话,我们也可以把它们当做内置对象。
自定义对象(user-defined object) 由运行中的js创建的对象。
自有属性(own property) 直接在对象当中定义的属性,区别于继承属性。
继承属性(inherited property) 在对象原型中定义的属性。
属性描述符对象
ES5中定义了一个属性描述符对象(property descriptor)。这个对象属性和他们所描述的属性特性是同名的。
value:属性的值值。
writable:可写性,是否可以设置值。
enumerable:可枚举性,遍历对象时该属性会不会出现。
configurable:可配置性。
作为属性特性的存取器
对象属性是由名字和值跟一组属性特性构成的,属性值可以用一个或两个方法进行替代,这两个方法就是getter和setter定义的属性特性。由getter和setter定义的属性叫做“存取器属性”。
存取器属性的特点:
1,当程序查询存取器属性值时,js调用getter方法。这个方法返回的就是属性存取表单式的值。
2,当程序设置存取器属性值是,js调用setter方法。这个方法将赋值表达式右边的计算结果,传入setter。
3,存取器属性不具有可写性,如果同时具有getter和setter方法那它就是一个读写属性。也可以只拥有其中一个,来作为只读或者只写属性。
定义存取器属性
var o = {
// 普通的数据属性
data:null;
// 存取器属性
set ODate(value){
this.data = value; // 处理复制表达式右侧计算结果(value)的属性设置表达式
},
get ODate(){
return this.data; // 属性返回表达式
}
}
// 设置data,获取data
o.OData = {id:0};
o.OData; =>{id:0}
获取自有属性的属性描述符对象Object.getOwnPropertyDescriptor()
// 当我们为对象创建属性时如果没有指定属性描述符,那就都是默认的 可枚举,可配置,可读写,
var obj = {
name:"小花"
}
console.log(Object.getOwnPropertyDescriptor(obj,"name"));
定义属性描述符对象Object.defineProperty(obj,attributeName,PropertyDescriptor)
// 定义cat的name属性为不可枚举(此后使用for in 遍历对象属性时,name不会出现),value为小花
var cat = {};
Object.defineProrerty(cat , "name",{
value:"小花",
enumerable:false
})
同时定义或修改对象的多个属性及其描述符Object.defineProperties()
// 参数一是目标对象,参数二是属性为键描述符为值的对象
var cat = Object.defineProperties({},{
name:{value:"小花"},
age:{value:6},
// 值为大菊,不可写
type:{value:"大菊",writable:false},
// 存取器特性替代属性值value,不可枚举
date:{
get:function(){return [this.name,this.age]},
enumerable:false
}
})
使用属性描述符实现jq中$.extend方法的部分功能:
1,给根对象Object的原型拓展一个extend方法。
2,接收要复制的目标对象,将他的属性和属性特性复制到调用对象。
3,复制规则:存在同名属性时保留原有属性,复制目标对象上的一切可枚举自有属性。
Object.defineproperty(Object.prototype,"extend",{
enumerable:false,
value:function(o){
// 得到O对象的所有自有属性名称列表
var proNames = Object.getOwnPropertyNames(o);
// 排除已存在属性
for(var i = 0; i < proNames.length; i++){
if(proNames[i] in this) continue;
// 获取该属性的属性描述符对象
var desc = Object.getOwnpropertyDescriptor(o,proName[i]);
// 将属性copy到调用对象
Object.defineProperty(this,proName[i],desc);
}
}
})
小结:
》三类对象:内置对象,宿主对象,自定义对象。
》两类属性:自有属性,继承属性。
》存取器属性:区别于数据属性,属性名称就是getter、setter方法名称。
》属性每个属性都拥有属性描述符对象,不显示定义属性的描述符对象时,他们默认都是可读写,可枚举,可配置的。
》ES5提供了两个API用来定义或修改属性及其描述符:
获取指定对象指定属性的属性描述符对象:Object.getOwnPropertyDescriptor()
同时定义多个属性及其描述符:Object.defineProperties()
定义单个属性及其描述符:Object.defineProperty(obj,attributeName,PropertyDescriptor)
》js中的普通对象能够从根对象上继承到它提供的属性方法。我们基于这个特性为根对象创建了一个extend方法可以用来复制其他对象上的自有可枚举属性。
js对象—类型和属性特性的更多相关文章
- js对象可扩展性和属性的四个特性(上)
# js对象可扩展性和属性的四个特性(上) 一.前言 再次花时间回顾一下基础,毕竟要想楼建的好,地基就要牢固,嘻嘻! 在开始之前需要具备对prototype.__proto__.constructor ...
- js对象可扩展性和属性的四个特性(下)
# js对象可扩展性和属性的四个特性(下) 一.前言 再次花时间回顾一下基础,毕竟要想楼建的好,地基就要牢固,嘻嘻! 在开始之前需要具备对prototype.__proto__.constructor ...
- 遍历js对象中的属性
可以使用js自带的for in.也可以使用Ext JS中的方法来遍历js对象中的属性 代码如下: /** 遍历对象 */ var person = {name:'张泰松',age:28}; //js方 ...
- JS对象类型的确定
JS是松散类型的语言,这一点JS的对象表现得尤为突出.那么如何来确定JS对象的具体类型呢? 首先,我们可以使用typeof运算符确定其基本类型(number,object,function,undef ...
- JavaScript中的对象描述符(属性特性)
我们先创建一个对象: var person = { name: "Nicholas", _job: "Software Engineer", sayName: ...
- 判断js对象类型
javascript中检测对象的类型的运算符有:typeof.constructor.instanceof.prototype. 1.typeof typeof是一个一元运算符,返回结果是一个说明运算 ...
- js 对象可枚举属性以及for in 循环和for of 循环
js中每个对象的属性(js里万物皆属性,对象的属性也是对象)都有一个属性叫enumerable(可枚举性),这个属性true/false决定了该对象的属性是否可枚举(就是让一些方法访问到这个属性). ...
- js对象类型判断工具
对象类型判断工具 /** *类功能:对象类型判断工具 **/ var TypeUtil = { /** *方法说明:是否是数组 **/ isArray: function (obj) {//是否是数组 ...
- js 对象类型 (对象的属性 ,对象的方法) this 关键字
$(function () { var observation = { init: function () { this.render();//断点:this bind :function() che ...
随机推荐
- iframe调用父页面js函数 方法 元素
在一个页面中添加iframe,但是有时需要与父页面进行通信,传递参数. 网上总结有以下方法: 一.iframe标签中 src属性传参 <iframe src="test.jsp?i ...
- maven的基本原理和使用
一.Maven中央存储库 当你建立一个 Maven 的项目,Maven 会检查你的 pom.xml 文件,以确定哪些依赖下载.首先,Maven 将从本地资源库获得 Maven 的本地资源库依赖资源,如 ...
- 第三章 Java 的基本程序设计结构
1.Java基本数据类型 Java中一共有8种基本数据类型. 4种整形:int-4字节.long-8字节.short-2字节.byte-1字节 2中浮点型:float-4字节.double-8字节 1 ...
- 【LeetCode】Rotate List
Given a list, rotate the list to the right by k places, where k is non-negative. For example:Given 1 ...
- Chain of Responsibility Pattern
1.Chain of Responsibility模式:将可能处理一个请求的对象链接成一个链,并将请求在这个链上传递,直到有对象处理该请求(可能需要提供一个默认处理所有请求的类,例如MFC中的Cwin ...
- Nodejs通过Thrift操作hbase卡住原因分析及与javascript的垃圾回收机制的关系
在最近使用Nodejs通过Thrift操作hbase的时候写了个脚本,不断发送http请求,从而取得hbase下所需的数据,但是在run的过程中for循环并没有执行完全,在执行一部分后会卡住,就再也进 ...
- android RefBase、sp、wp
首先RefBase在android的c++部分是作为一个所有类的基类,其作用跟Java中的Object类似 这个类中存在一个私有成员: weakref_impl* const mRefs;(weakr ...
- BZOJ 1623 [Usaco2008 Open]Cow Cars 奶牛飞车:贪心
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1623 题意: 编号为1到N的N只奶牛正各自驾着车打算在牛德比亚的高速公路上飞驰.高速公路有 ...
- 精选Java面试题
什么是隐式类型转换?什么是显示类型转换? 当将占位数少的类型赋值给占位数多的类型时,Java自动使用隐式类型转换(如int型转为long型).当把在级别高的变量的值赋给级别底变量时,必须使用显示类型转 ...
- Android之styles.xml,以及自定义风格
1.styles.xml 在现在的ADT创建的Project中,会有values,values-v11和values-v14三个文件夹,每个文件夹下都有一个styles.xml. API11是Andr ...