第三部分继续...

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学习笔记(三)的更多相关文章

  1. ECMAScript5之Object学习笔记(一)

    随着IE的逐步追赶,目前到IE11已经能够很好的支持ECMAScript5标准了,其他的现代浏览器像firefox,chrome,opera就更不用说了. 再加上nodejs使得javascript在 ...

  2. ECMAScript5之Object学习笔记(二)

    继续第二部分 Object.freeze(obj) 看字面意思就是“把一个对象冻结”. 下面我们来看个简单的例子以作说明: // a person instance var person = { na ...

  3. 学习笔记(三)--->《Java 8编程官方参考教程(第9版).pdf》:第十章到十二章学习笔记

    回到顶部 注:本文声明事项. 本博文整理者:刘军 本博文出自于: <Java8 编程官方参考教程>一书 声明:1:转载请标注出处.本文不得作为商业活动.若有违本之,则本人不负法律责任.违法 ...

  4. openresty 学习笔记三:连接redis和进行相关操作

    openresty 学习笔记三:连接redis和进行相关操作 openresty 因其非阻塞的调用,令服务器拥有高性能高并发,当涉及到数据库操作时,更应该选择有高速读写速度的redis进行数据处理.避 ...

  5. ZooKeeper学习笔记三:使用ZooKeeper实现一个简单的配置中心

    作者:Grey 原文地址:ZooKeeper学习笔记三:使用ZooKeeper实现一个简单的配置中心 前置知识 完成ZooKeeper集群搭建以及熟悉ZooKeeperAPI基本使用 需求 很多程序往 ...

  6. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  7. [Firefly引擎][学习笔记三][已完结]所需模块封装

    原地址:http://www.9miao.com/question-15-54671.html 学习笔记一传送门学习笔记二传送门 学习笔记三导读:        笔记三主要就是各个模块的封装了,这里贴 ...

  8. JSP学习笔记(三):简单的Tomcat Web服务器

    注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...

  9. java之jvm学习笔记三(Class文件检验器)

    java之jvm学习笔记三(Class文件检验器) 前面的学习我们知道了class文件被类装载器所装载,但是在装载class文件之前或之后,class文件实际上还需要被校验,这就是今天的学习主题,cl ...

随机推荐

  1. 【推导】【数学期望】【冒泡排序】Petrozavodsk Winter Training Camp 2018 Day 5: Grand Prix of Korea, Sunday, February 4, 2018 Problem C. Earthquake

    题意:两地之间有n条不相交路径,第i条路径由a[i]座桥组成,每座桥有一个损坏概率,让你确定一个对所有桥的检测顺序,使得检测所需的总期望次数最小. 首先,显然检测的时候,是一条路径一条路径地检测,跳跃 ...

  2. zoj 3469 区间dp **

    题意:有一家快餐店送外卖,现在同时有n个家庭打进电话订购,送货员得以V-1的速度一家一家的运送,但是每一个家庭都有一个不开心的值,每分钟都会增加一倍,值达到一定程度,该家庭将不会再订购外卖了,现在为了 ...

  3. bzoj 4034

    我写的是 DFS序+线段树 DFS序(出去的位置要单独建点)上,进入的位置是权值,出去的位置是权值的相反数,可以证明节点i到根节点的路径上的点的权值和是DFS序上1-in[i]的和. 只要搞出每个区间 ...

  4. Jmeter实现登录、创建BUG、解决bug的手写脚本

    一.登录 1.          打开jmeter.添加线程组,命名为test,如下图: 2.          添加HTTp默认请求 1)服务器名称或IP:这里只能填写域名或IP地址 2)端口号:配 ...

  5. SQLite3知识(1)--教程

    1.SQLite3教程 [1].SQLite 教程 2.选择数据库: [2]. SQLite Select 语句 3.更新数据库: [3]. SQLite Update 语句 4.插入数据库: [4] ...

  6. linux基础环境部署

    Content 0.序 1.更新安装库 2.安装基础库 0.序 本文主要是记录php在 Centos下的安装配置 .文中如无特别说明.表示php-5.6.31代码目录. 1.更新安装库 $ yum u ...

  7. Go 收藏

    Golang 定位解决分布式系统,服务器应用开发,主要竞争对手是 Java.Python 之类:Rust 定位解决单机安全问题,高性能场景偏系统底层开发,主要竞争对手就是 C 和 C++. Golan ...

  8. Windows程序调试系列: 使用VC++生成调试信息 转

    Windows程序调试系列: 使用VC++生成调试信息 ZhangTao,zhangtao.it@gmail.com, 译自 “Generating debug information with Vi ...

  9. Python基础教程学习(三)

    如何定义类 class ClassName(base_class[es]): "optional documentation string" static_member_decla ...

  10. PyQt5 布局

    import sys from PyQt5.QtWidgets import QWidget, QLabel, QApplication, QVBoxLayout, QHBoxLayout, QPus ...