ES5对象(超类)原有:

属性:construct构造函数

方法:

object.hasOwnProperty( propertyName )  //检测是否有一个本地的属性而不是继承的,返回boolen
prototypeObject.isPrototypeOf( object )  //检测指示对象是否存在于另一个对象的原型链中,返回boolen
propertyIsEnumerable()  //指定属性是否为对象的一部分以及该属性是否是可枚举的,返回boolen
var arr = [1, 2];
arr.propertyIsEnumerable( 1 ) ; // true
// 数组的length为内置属性
arr.propertyIsEnumerable( "length" ) // false
object.valueOf( )  //返回指定对象的原生值
// Date:当前时间距1970年1月1日午夜的毫秒数
var date = new Date(2013, 7, 18, 23, 11, 59, 230);
date.valueOf() ; // // Number:返回数字值
var num = 15.26540;
num.valueOf() ; // 15.2654

静态方法:


property特征:

1. value:值,默认是undefined

2. writable:是否可更改,默认是false

3. enumerable:是否可以被枚举(for in),默认false

4. configurable:是否可以被删除,默认false

get/set不能和value、writable同时使用

5.get:返回property的值得方法,默认是undefined

6.set:为property设置值的方法,默认是undefined


Object.create(prototype[,descriptors])  //通过指定原型及属性创建一个新对象

var d = Object.create({a:1});
console.log(d);  //Object {a:1}
var e = Object.create(Array);
console.log(e);  //Function {}

Object.defineProperties()  //创建或配置多个属性

Object.defineProperty()  //创建或配置某个属性

var o = {};   //这里的o对象必须提前定义
//多个属性
Object.defineProperties(o, {
'age': {
value: 24,
writable: true,
enumerable: true,
configurable: true
},
'sex': {
value: 'male',
writable: false,
enumerable: false,
configurable: false
}
});
console.log(o); //Object {age: 24, sex: "male"} //单个属性
Object.defineProperty(o,'age', {
value: 24,
writable: true,
enumerable: true,
configurable: true
});

Object.getOwnPropertyDescriptor(obj,property)  //获取指定对象的指定属性

var props = Object.getOwnPropertyDescriptor(o, 'age');
console.log(props); //Object {value: 24, writable: true, enumerable: true, configurable: true}

Object.getOwnPropertyNames()  //返回指定对象的所有非继承包括不可枚举属性名的数组

console.log(Object.getOwnPropertyNames(o)); //["age", "sex"]

Object.getPrototypeOf()  //返回指定对象的原型

Object.keys()  //返回指定对象所有非继承可枚举属性名的数组(注意与getOwnPropertyNames的区别)

Object.preventExtensions(obj)//阻止向指定对象添加新的属性,但是仍可以更改旧的属性

Object.isExtensible(obj) //检测对象是否可以添加新的属性

Object.seal(obj)  //阻止向指定对象添加新属性或者是删除现有属性

Object.isSealed(obj)  //检测是否密封

Object.freeze(obj)  //完全冻结,属性的一切操作均无效

Object.isFrozen(obj)  //是否已冻结

ES6对象的扩展

属性的简化:

ES6允许直接写入变量和函数,作为对象的属性和方法

var birth = '2000/01/01';

var Person = {

  name: '张三',

  //等同于birth: birth
birth, // 等同于hello: function ()...
hello() { console.log('我的名字是', this.name); } };

注意,属性名表达式与简洁表示法,不能同时使用,会报错。

// 报错
var foo = 'bar';
var bar = 'abc';
var baz = { [foo] }; // 正确
var foo = 'bar';
var baz = { [foo]: 'abc'};

函数的name属性,返回函数名。对象方法也是函数,因此也有name属性。如果使用了取值函数,则会在方法名前加上get。如果是存值函数,方法名的前面会加上set

var person = {
sayName() {
console.log(this.name);
},
get firstName() {
return "Nicholas"
}
} person.sayName.name // "sayName"
person.firstName.name // "get firstName"

有两种特殊情况:bind方法创造的函数,name属性返回“bound”加上原函数的名字;Function构造函数创造的函数,name属性返回“anonymous”。

(new Function()).name // "anonymous"

var doSomething = function() {
// ...
};
doSomething.bind().name // "bound doSomething"

如果对象的方法是一个Symbol值,那么name属性返回的是这个Symbol值的描述

const key1 = Symbol('description');
const key2 = Symbol();
let obj = {
[key1]() {},
[key2]() {},
};
obj[key1].name // "[description]"
obj[key2].name // ""

Object.is()

+0 === -0 //true
NaN === NaN // false Object.is(+0, -0) // false
Object.is(NaN, NaN) // true

Object.assign()第一个参数是目标对象,后面的参数都是源对象。用于对象合并,将源对象(source)的所有可枚举属性,复制到目标对象(target)。

注意,如果目标对象与源对象有同名属性,或多个源对象有同名属性,则后面的属性会覆盖前面的属性。

var target = { a: 1, b: 1 };

var source1 = { b: 2, c: 2 };
var source2 = { c: 3 }; Object.assign(target, source1, source2);
target // {a:1, b:2, c:3}

只有一个参数则返回参数,如果这个参数不为对象,则直接转为对象,但是undefined和null不可以。

ES6入门之对象扩展的更多相关文章

  1. ES6入门——数值的扩展

    1.二进制和八进制表示法 ES6提供了二进制和八进制数值的新的写法,分别用前缀0b或0B和0o或0O表示. 2.Number.isFinite(),Number.isNaN() ES6在Number对 ...

  2. ES6入门——正则的扩展

    1.RegExp构造函数 在ES5中,RegExp构造函数的参数有两种情况.第一种情况是参数是字符串,这时第二个参数表示正则表达式的修饰符:第二种情况是,参数是一个正则表示式,这时会返回一个原有正则表 ...

  3. ES6入门——函数的扩展

    1.函数参数的默认值 在ES6之前,不能直接为函数的参数指定默认值,只能采用变通的方法.现在ES6可以为函数的参数添加默认值,简洁了许多. ES5 function show(a,b){ b = b ...

  4. ES6学习之对象扩展

    简介表示法(直接写入变量和函数,作为对象的属性和方法) let x = "test" let obj={ x, //属性名为变量名,属性值为变量值 y(){console.log( ...

  5. es6 语法 (对象扩展)

    { //简洁表示法 let o = 1; let k = 2; let es5 = { o:o, k:k }; let es6 = { o,k }; console.log(es5,es6); //1 ...

  6. ES6入门系列 ----- 对象的遍历

    工作中遍历对象是家常便饭了,遍历数组的方法五花八门, 然而很多小伙伴是不是和我之前一样只会用for ...in.... 来遍历对象呢, 今天给大家介绍五种遍历对象属性的方法: 1, 最常用的for  ...

  7. ES6入门教程---数值扩展和数组扩展

    1.数值扩展 var num = 0b11; console.log(num);3 var num = 0o11;console.log(num);9 var num = 1.234; console ...

  8. ES6对象扩展

    前面的话 随着JS应用复杂度的不断增加,开发者在程序中使用对象的数量也在持续增长,因此对象使用效率的提升就变得至关重要.ES6通过多种方式来加强对象的使用,通过简单的语法扩展,提供更多操作对象及与对象 ...

  9. es6之函数扩展与对象扩展

    一.函数扩展 1.参数默认值 参数有默认值,后面不可以再加没有默认值的变量.如以下test函数中,不可以加写成 function test(x,y="word",z){ } fun ...

随机推荐

  1. Kafka学习之(一)了解一下Kafka及关键概念和处理机制

    Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模小打的网站中所有动作流数据.优势 高吞吐量:非常普通的硬件Kafka也可以支持每秒100W的消息,即使在非常廉价的商用机器上也能做 ...

  2. Django----Request对象&Response对象

    Django 使用Request 对象和Response 对象在系统间传递状态. HttpRequest 对象: Request.body:一个字节字符串,表示原始HTTP 请求的正文.它对于处理非H ...

  3. MVC中一个Form多个submit在controller中如何区分提交的是那个submit(如:登陆和注册)

    1. 用Html.BeginForm(ActionName,ControllerName,Post)来实现controller-action的路由, 2. Form里的每个input的name值统一, ...

  4. 同一个tomcat启动多个实例

    一般在使用Tomcat时,服务器会从conf及webapps目录中读取配置文件,并将文件写入logs.temp和work目录,当然一些jar文件和class文件需要从服务器的公共目录树中予以加载.因此 ...

  5. web服务器安全笔记

    一.设置项目目录权限(centos ,apache为例) 1.chown -R root /var/www/html/project   (设置项目所属的用户) 2.chgrp  -R root /v ...

  6. python中的上下文管理器

    刚刚看了vamei大神的上下文管理器博客,理解如下: 其实我自己经常用到上下文管理器,尤其是在打开文件的时候,如果自己比较懒,不想手工打上f.close(),使用上下文管理器就ok拉. 上下文管理器就 ...

  7. Linux 实用操作命令

    1. ssh远程连接服务器命令 ssh [username@]hostname 2. 查看远程服务器近期登陆记录 last 3. 用户及其主目录的创建 1.  useradd –d /home/lb ...

  8. C# 自动触发鼠标、键盘事件

    要在C#程序中触发鼠标.键盘事件必须要调用windows函数. 一.鼠标事件的触发 1.引用windows函数mouse_event /// <summary> /// 鼠标事件 /// ...

  9. centos7 systemctl一些用法

    systemctl 是管制服务的主要工具, 它整合了chkconfig 与 service功能于一体. systemctl is-enabled servicename.service #查询服务是否 ...

  10. Python笔试、面试 【必看】

    本文由EarlGrey@编程派独家编译,转载请务必注明作者及出处. 原文:Sheena@codementor 译文:编程派 引言 想找一份Python开发工作吗?那你很可能得证明自己知道如何使用Pyt ...