《深入理解ES6》之扩展对象的功能性

 

属性初始值的简写

  当一个对象的属性与本地变量同名时,不必再写冒号和值,简单地只写属性名即可。

function createPerson(name,age){
    return {
        name,
        age
    };
}
//相当于
function createPerson(name,age){
    return {
        name:name,
        age:age
    };
}

对象方法的简写

  ES6中对对象字面量定义方法的语法进行了改进,消除了冒号和function关键字。

var person={
    name:"jiaxiaonuo",
    age:24,
    sayName(){
        console.log(this.name);
    }
};
//相当于
var person={
    name:"jiaxiaonuo",
    age:24,
    sayName:function(){
        console.log(this.name);
    }
};

可计算属性名

  在ES5及早期版本的对象实例中,如果想要通过计算得到属性名,就需要用方括号代替点记法。有些包括某些字符的字符串字面量作为标识符会出错,其和变量放在方括号中都是被允许的。在ES6中,可在对象字面量中使用可计算属性名称,其语法与引用对象实例的可计算属性名称相同,也是使用方括号。

let lastName="last name";
let person={
    "first name":"jia",
    [lastName]:"xiaonuo"
};
console.log(person["first name"]);//"jia"
console.log(person[lastName]);//"xiaonuo"

Object.is()方法

  由于全等运算符(===)在判断NaN===NaN的返回值为false,同时判断+0===-0时返回值为true。而正常情况下,这两个判断结果是恰恰相反。这时使用Object.is()可以对上面的不足进行正确判断。正常情况下还是使用全等运算符进行判断,只有碰到上面两种特殊情况可以使用Object.is()进行判断。

console.log(+0===-0);//true
console.log(Object.is(+0,-0);//false

console.log(NaN===NaN);//false
console.log(Object.is(NaN,NaN);//true

Object.assign()方法

  混合(Mixin)方法中,一个对象接收来自另一个对象的属性和方法。任何使用mixin()方法的地方都可以直接使用Object.assign()方法来替换,同时Object.assign()方法可以接受任意数量的源对象,并按指定的顺序将属性复制到接收对象中。

var receiver={};
Object.assign(receiver,
     {
        type:"js",
        name:"file.js"
     },
    { 
        type:"css"      
    } 
);
console.log(receiver.type);//"css"
console.log(receiver.css);//"file.js
 

 

重复的对象字面量属性

  ES5严格模式中加入对象字面量重复属性的校验,当同时存在多个同名属性时会抛出错误。在ES6中重复属性检查被移除,一旦出现重复属性,都会选择最后一个取值。

“use strict”

var person={
    name:"jia",
    name:"nuo"
};

console.log(person.name);//"nuo"

 

自有属性枚举顺序

  1.所有数字键按升序排序。

  2.所有字符串键按照他们被加入对象的顺序排序。

  3.所有symbol键按照他们被加入对象的顺序排序。

var obj ={
    a:1,
    0:1,
    c:1,
    2:1,
    b:1,
    1:1
};
obj.d=1;
console.log(Object.getOwnPropertyNames(obj).join(""));//"012acbd"

 

Object.setPrototypeOf()方法

  该方法可以任意指定对象的原型,他接受两个参数:被改变圆形的对象和替代第一个参数原型的对象。

let person={
    getGreeting(){
        return "hello";
    }
};
let dog={
    getGreeting(){
        return "woo";
    }
};

let friend=Object.create(person);
console.log(friend.getGreeting());//"hello"
console.log(Object.getPrototypeOf(friend)===person);//true

Object.setPrototypeOf(friend,dog);
console.log(friend.getGreeting());//"woo"
console.log(Object.getPrototypeOf(friend)===dog);//true

 

super可以简化原型访问

  必须在使用简写方法的对象中使用super引用,但如果在其他方法声明中使用会导致语法错误。

let person={
    getGreeting(){
        return super.getGreeting()+"hi!";
    }
};
//相当于

let person={
    getGreeting(){
        return Object.getPrototypeOf(this).getGreeting.call(this)+",hi!";

 

 

  

 

posted @ 2017-08-05 12:59  水迹仙涯  阅读(361)  评论(0编辑  收藏  举报