ECMAScript5之Object学习笔记(三)
第三部分继续...
Object.getOwnPropertyDescriptor(obj, prop)
获取一个对象的属性描述符
根据"Own"这个词我们可以猜到,prop只能是obj的“直接”属性,prototype链上的无效
来几个直观的例子,以作说明:
var person = {},
nameDesc, // name descriptor
titleDesc, // title descriptor
ageDesc; // age descriptor
person.name = 'Andrew';
nameDesc = Object.getOwnPropertyDescriptor(person, 'name');
console.dir(nameDesc);
// { "configurable": true, "enumerable": true, "value": "Andrew", "writable": true }
Object.defineProperty(person, 'title', {
value: 'sales manager',
writable: true
});
titleDesc = Object.getOwnPropertyDescriptor(person, 'title');
console.dir(titleDesc);
// { "configurable": false, "enumerable": false, "value": "sales manager", "writable": true }
var _age = 25;
Object.defineProperty(person, 'age', {
get: function() {
return _age + ' years old';
},
set: function(age) {
_age = age;
}
});
person.age = 20;
console.log(_age); //
console.log(person.age) // 20 years old
ageDesc = Object.getOwnPropertyDescriptor(person, 'age');
console.dir(ageDesc);
// { "configurable": false, "enumerable": false, "get": function () {...}, "set": function (age) {...} }
Object.getOwnPropertyNames(obj)
获取对象的(非原型链上的)“直接”属性名集合(无论该属性是否可列举)
代码示例如下:
var arr = ['1st', '2nd', '3rd'];
console.log( Object.getOwnPropertyNames(arr) );
// ["0", "1", "2", "length"] var usa = {
president: 'Obama',
states: 52
};
console.log( Object.getOwnPropertyNames(usa) );
// ["president", "states"] Object.defineProperty(usa, 'population', {
enumerable: false,
value: '300million'
});
// 即使属性不可列举,依然能获得
console.log( Object.getOwnPropertyNames(usa) );
// ["president", "states", "population"]
Object.getPrototypeOf(obj)
返回对象的prototype
上代码:
var Base = function() {}
Base.prototype.base_method1 = function() {};
Base.prototype.base_method2 = function() {};
var base = new Base();
console.log( Object.getPrototypeOf(base) );
// { base_method1: function, base_method2: function }
var Sub = function() {
Base.call(this);
}
Sub.prototype = Object.create(Base.prototype);
Sub.prototype.constructor = Sub;
Sub.prototype.sub_method1 = function() {};
var sub = new Sub();
console.log( Object.getPrototypeOf(sub) );
// { constructor: function, sub_method1: function, base_method1: function, base_method2: function }
为了方便说明,chrome中输出的内容如下:

从上面的例子,可以发现Object.getPrototypeOf(obj)可以返回对象的prototype,并且通过prototype链(通过__proto__)可以查看到”基类“从”父类“上继承的方法(或属性)。
在chrome中还可以看到返回的prototype对象包括constructor(构造函数)和__proto__(非标准,但现代浏览器都支持,当然IE除外)
Object.keys(obj)
返回对象自身的可列举属性集合
上代码:
var arr = ['Tom', 'Focker', 'linkon'];
console.log( Object.keys(arr) );
// ["0", "1", "2"] var person = {
name: 'Andrew',
age: 25,
gender: 'male'
};
console.log( Object.keys(person) );
// ["name", "age", "gender"] Object.defineProperty(person, 'address', {
value: 'SuZhou,China',
enumerable: false
});
// address属性不可以列举,所以Object.keys的返回结果不变
console.log( Object.keys(person) );
// ["name", "age", "gender"]
第三部分就到此为止。
ECMAScript5之Object学习笔记(三)的更多相关文章
- ECMAScript5之Object学习笔记(一)
随着IE的逐步追赶,目前到IE11已经能够很好的支持ECMAScript5标准了,其他的现代浏览器像firefox,chrome,opera就更不用说了. 再加上nodejs使得javascript在 ...
- ECMAScript5之Object学习笔记(二)
继续第二部分 Object.freeze(obj) 看字面意思就是“把一个对象冻结”. 下面我们来看个简单的例子以作说明: // a person instance var person = { na ...
- 学习笔记(三)--->《Java 8编程官方参考教程(第9版).pdf》:第十章到十二章学习笔记
回到顶部 注:本文声明事项. 本博文整理者:刘军 本博文出自于: <Java8 编程官方参考教程>一书 声明:1:转载请标注出处.本文不得作为商业活动.若有违本之,则本人不负法律责任.违法 ...
- openresty 学习笔记三:连接redis和进行相关操作
openresty 学习笔记三:连接redis和进行相关操作 openresty 因其非阻塞的调用,令服务器拥有高性能高并发,当涉及到数据库操作时,更应该选择有高速读写速度的redis进行数据处理.避 ...
- ZooKeeper学习笔记三:使用ZooKeeper实现一个简单的配置中心
作者:Grey 原文地址:ZooKeeper学习笔记三:使用ZooKeeper实现一个简单的配置中心 前置知识 完成ZooKeeper集群搭建以及熟悉ZooKeeperAPI基本使用 需求 很多程序往 ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- [Firefly引擎][学习笔记三][已完结]所需模块封装
原地址:http://www.9miao.com/question-15-54671.html 学习笔记一传送门学习笔记二传送门 学习笔记三导读: 笔记三主要就是各个模块的封装了,这里贴 ...
- JSP学习笔记(三):简单的Tomcat Web服务器
注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...
- java之jvm学习笔记三(Class文件检验器)
java之jvm学习笔记三(Class文件检验器) 前面的学习我们知道了class文件被类装载器所装载,但是在装载class文件之前或之后,class文件实际上还需要被校验,这就是今天的学习主题,cl ...
随机推荐
- Visual Studio 2017强制更新方法
Visual Studio 2017强制更新方法 Visual Studio 2017更新时候,用户都是根据消息提示,进行更新.这样做的好处,就是微软可以分批下发升级包,避免集中更新.不过为了早点 ...
- iOS 9应用开发教程之使用代码添加按钮美化按钮
iOS 9应用开发教程之使用代码添加按钮美化按钮 丰富的用户界面 在iOS9中提供了很多的控件以及视图来丰富用户界面,对于这些视图以及控件我们在上一章中做了简单的介绍.本章我们将详细讲解这些视图. i ...
- thinkphp的_STORAGE_WRITE_ERROR_问题
今天服务器突然报这个问题(上图所示),在thinkphp的官网上也发现有朋友碰到这个问题,定位到应该是Runtime目录没有写权限,然后试着给Application下的Runtime目录 chmod ...
- 20162325 金立清 S2 W11 C20
20162325 2017-2018-2 <程序设计与数据结构>第11周学习总结 教材关键概念摘要 在哈希方法中,元素保存在哈希表中,其在表中的位置由哈希函数确定. 两个元素或关键字映射到 ...
- PIVOT函数与UNPIVOT函数的运用
PIVOT用于将行转为列,完整语法如下: TABLE_SOURCE PIVOT( 聚合函数(value_column) FOR pivot_column IN(<column_list>) ...
- saga中的saga(A Saga on Sagas)
此文翻译自msdn,侵删. 原文地址:https://msdn.microsoft.com/en-us/library/jj591569.aspx Process Managers, Coordina ...
- Apache参数的优化(转)
按照前面提到的版本问题,Apache可以直接使用2.0版本产品线.针对Apache的优化主要是针对httpd.conf的优化,当然还有其他地方,如果特别留意的话,网上常有专家惊呼“居然这么多人忽略xx ...
- php输出mysqli查询出来的结果
php连接mysql我有文章已经写过了,这篇文章主要是介绍从mysql中查询出结果之后怎么输出的问题. 一:mysqli_fetch_row(); 查询结果:array([0]=>小王) 查询: ...
- Extjs文件选择器
Ext.hoo.component.FileBrowserComponent.js /** * Ext.hoo.component.FileBrowserWindow 系统文件浏览选择组件,可以选定电 ...
- jQuery元素属性attr设置多个键值或函数 删除属性removeAttr
$("Element").attr(name) '取得第一个匹配的属性值,比如$("img").attr("src") $("El ...