小米技术社区
小米技术社区管理员 关于小米

27岁,山西运城人,职业电商经理人,前端开发工作者,从事过网站建设、网络推广、SEO、SEM、信息流推广、二类电商、网络运维、软件开发,等相关电商工作,经验较为丰富,小米技术社区致力于为广大从事Web前端开发的人员提供一些力所能及的引导和帮助 ...[更多]

E-mail:mzze@163.com

Q Q:32362389

W X:xiaomi168527

小米技术社区大牛王飞 关于王飞

27岁,山西运城人,职业电商经理人,网络工程师兼运维,从事过运营商网络建设,企业网络建设、优化。数据中心网络维护等通过,经验丰富,座右铭:当自己休息的时候,别忘了别人还在奔跑。 ...[更多]

E-mail:wf_live@126.com

Q Q:3940019

微博:王小贱ss

小米技术社区设计小艳 关于小艳

大于花一样的年龄,河南郑州是我家,2010年在北京接触团购网,2011年进入天猫淘宝一待就是四年,如今已经将设计走向国际化(ps:误打误撞开始进入阿里巴巴国际站的设计,嘿嘿)五年电商设计,丰富经验,从事过天猫淘宝阿里各项设计,店铺运营,产品拍摄;我将我的经历与您分享是我的快乐!座右铭:越努力越幸运! ...[更多]

E-mail:97157726@qq.com

Q Q:97157726

标签云
精品推荐
  • 什么是闭包?js闭包的2个最大用途以及注意事项

    什么是闭包?js闭包的2个最大用途以及注意事项

    各种专业文献上的"闭包"(closure)定义非常抽象,很难看懂。简单的说,闭包就是能够读取其他函数内部变量的函数。由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因……
    94人已经看过了
您的位置:首页 > 前端开发 > Javascript > 原生JS

ES6的Symbol数据类型

分类: 原生JS8个赞

ES5数据类型:6种: string  number boolean  null  undefined  object

ES6新增了一种数据类型:Symbol,表示独一无二的值,Symbol最大的用途是用来定义对象的唯一属性名。


Symbol值通过Symbol函数生成。

var symbol1 = Symbol();
var symbol2 = Symbol("Alice");
console.log(symbol1, symbol2) // 输出:Symbol() Symbol(Alice)


typeof运算符用于Symbol类型值,返回symbol。

console.log(typeof Symbol("Alice")) // 输出:symbol


Symbol类型的值是一个独一无二的值,和本身也不相等,Symbol函数的参数只是表示对当前Symbol值的描述,因此相同参数的Symbol函数的返回值是不相等的。

console.log(Symbol() == Symbol()); // 输出:false
console.log(Symbol("Alice") == Symbol("Alice")); // 输出:false


Symbol的应用:作为对象属性名的Symbol,防止重复

//作用:独一无二 对象中成员名取名,防止重复
    // var say = 'abc';
    var obj = {
        "age":40,
        "sex":"男",
        [Symbol()]:"100",
    };

    obj[Symbol()] = 200;
    console.log(obj);

    //如果要取出属性值,需要给独一无二的值,声明一个变量
    //能够防止对象的属性名重复。但是不能保证变量名不重复
    var attr_name = Symbol();
    obj[attr_name] = 300;
    console.log(obj[attr_name]);

注意:注:Symbol值作为对象属性名时,不能用点运算符。由于点运算符后面总是字符串,所以不会读取attr_name作为标识名所指代的那个值。

使用[]方括号,里面的attr_name不带引号,表示attr_name是一个变量.


小米技术社区

本站内容均为小米原创,转载请注明出处:小米技术社区>> ES6的Symbol数据类型