zoukankan      html  css  js  c++  java
  • ES6-对象的扩展-属性名表达式

    JavaScript 定义对象的属性,有两种方法。

        var obj = {
        foo: true,
        abc: 123
        };

    上面代码的方法一是直接用标识符作为属性名,方法二是用表达式作为属性名,这时要将表达式放在方括号之内。

    但是,如果使用字面量方式定义对象(使用大括号),在 ES5 中只能使用方法一(标识符)定义属性。

        var obj = {
        foo: true,
        abc: 123
        };

    ES6 允许字面量定义对象时,用方法二(表达式)作为对象的属性名,即把表达式放在方括号内。

        let lastWord = 'last word';
         
        const a = {
        'first word': 'hello',
        [lastWord]: 'world'
        };
         
        a['first word'] // "hello"
        a[lastWord] // "world"
        a['last word'] // "world"
    

    表达式还可以用于定义方法名。

        let obj = {
        ['h' + 'ello']() {
        return 'hi';
        }
        };
         
        obj.hello() // hi
    

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

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

    注意,属性名表达式如果是一个对象,默认情况下会自动将对象转为字符串 [object Object],这一点要特别小心。

        const keyA = {a: 1};
        const keyB = {b: 2};
         
        const myObject = {
        [keyA]: 'valueA',
        [keyB]: 'valueB'
        };
         
        myObject // Object {[object Object]: "valueB"}
    

    上面代码中,[keyA] 和 [keyB] 得到的都是 [object Object],所以 [keyB] 会把 [keyA] 覆盖掉,而 myObject 最后只有一个 [object Object] 属性。

  • 相关阅读:
    ZOJ1542 POJ1861
    Codeforces Round #194 (Div. 2) 部分题解
    SRM585 div2
    hdu 4627 The Unsolvable Problem
    hdu 4622 Reincarnation
    hdu 4617 Weapon
    hdu 4609 3-idiots
    hdu 4616 Game
    hdu 4611 Balls Rearrangement
    hdu 4618 Palindrome Sub-Array
  • 原文地址:https://www.cnblogs.com/jiapengsongweb/p/10741272.html
Copyright © 2011-2022 走看看