ES6标准入门 第3版 读书笔记之Symbol

Symbol

  • ES6引入了一种新的原始数据类型Symbol,表示独一无二的值。
  • JS数据类型有:undefined,null,布尔值,字符串,数值,对象,Symbol
  • Symbol值通过Symbol函数生成:
    let s = Symbol();
    s  // Symbol()
    typeof s  // "symbol"
    
  • Symbol函数前不能使用new命令,会报错;
  • Symbol函数可以接受一个字符串作为参数,表示对Symbol实例的描述。
    注意:Symbol函数的参数只是表示对当前 Symbol值得描述,因此相同参数的Symbol函数的返回值是不相等的。
    let s = Symbol('abc');
    s   // Symbol(abc)
    s.toString() // "Symbol(abc)"
    
  • 如果Symbol的参数是一个对象,就会调用该对象的toString方法,将其转为字符串,然后才生成一个Symbol
  • 注意:
    1. Symbol值不能与其他类型的值进行运算,会报错;
    2. Symbol值可以显式转为字符串
    3. Symbol值也可以转为布尔值,但是不能转为数值

Symbol.prototype.description

  • ES2019提供了一个实例属性description,直接返回Symbol的描述

    const s = Symbol('foo');
    s.description   // "foo"
    
  • Symbol可以作为属性名

    let s = Symbol();
    // 写法一:
    let a = {};
    a[s] = 'abc';
    // 写法二:
    let a = {
    	[s]:'abc'
    };
    // 写法三:
    let a = {};
    Object.defineProperty(a,s,{value:'abc'});
    
    // 以上写法都得到同样的结果
    a[s]   // "abc"
    

    注意:

    1. Symbol值作为对象属性名的时候,不能用点运算符
    2. 常量使用Symbol值最大的好处是其他任何值都不可能有相同的值了
    3. Symbol值作为属性名时,该属性是公开属性,不是私有属性

实例:消除魔术字字符串

属性名的遍历

Symbol作为属性名,遍历对象的时候,该属性不会出现在for...in,for...of循环中,也不会被Object.keys(),Object.getOwnPropertyNames(),JSON.stringify()返回。
有一个Object.getOwnPropertySymbols()方法,可以获取指定对象的所有Symbol属性名。该方法返回一个数组,成员是当前对象的所有作用属性名的Symbol值。

Symbol.for() , Symbol.keyFor()

实例:模块的Singleton模式

内置的Symbol

  • Symbol.hasInstance
  • Symbol.isConcatSpreadable
  • Symbol.species
  • Symbol.match
  • Symbol.replace
  • Symbol.search
  • Symbol.split
  • Symbol.iterator
  • Symbol.toPrimitive
  • Symbol.toStringTag
  • Symbol.unscopables
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

神小夜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值