javaScript的数据类型:number,string,boolean,undefined,null,object

ES6带来了一个新的数据类型:symbol

目的是:解决对象的属性名冲突的问题。

let sm1=Symbol();

let sm2=Symbol();

console.log(sm1);   //Symbol()

console.log(sm2);   //Symbol()

console.log(typeof sm1)    //symbol

console.log(sm1===sm2)   //false

从测试可以发现 虽然sm1和sm2看起来很一样,但他们其实是不相等的。为了让不同的Symbol看起来不一样,我们可以通过参数来实现:

let sm1=Symbol('sm1');

let sm2=Symbol('sm2');

console.log(sm1);   //Symbol(sm1)

console.log(sm2);   //Symbol(sm2)

参数就像是Symbol的描述,用来区分看起来相同,实则不同的Symbol,但要注意,即使描述相同,sm1和sm2也不同,毕竟他们本来就是不同的东西。

下面我们来看用Symbol解决对象属性命名冲突的注意问题:

(1)当symbol值作为对象的属性名时,不能用点号来取得对应的属性值。

let name=Symbol();

let person={

  [name]:'Lily'     //以Symbol作为属性名name

};

console.log(person[name])  //Lily

console.log(person.name)    //undefined  不能用点号来取得对应的属性值

(2)当symbol值作为对象的属性名时,也不能用点号来设置对应的属性值

let name=Symbol();

let person={}

paseon.name='Lily'     //以Symbol作为属性名name,以点号赋值。

console.log(person[name])  //undefined 不能用点号来设置对应的属性值

console.log(person['name'])  //Lily

console.log(person.name)    //Lily

可以看出,当用点号赋值时,其实javascript就不会把点号后的值理解为symbol类型,而是字符串类型,就相当于没有使用symbol

(3)如何遍历symbol类型的属性名:Object.getOwnPropertySymbols()

let name=Symbol();

let person={

  [name]:'Lily' ,    //symbol类型

  'age':12   //string类型

};

Object.keys(person)   //['age']

for(let key in person){

  console.log(key)   // age

}

我们发现使用Object.keys()和for...in都无法遍历出symbol类型的属性。

我们可以用Object.getOwnPropertySymbols()来获取symbol类型的属性:

Object.getOwnPropertySymbols(person) //  [Symbol(name)]

(4)获取对象上的所有属性名:Reflect.ownKeys()

Reflect.ownKeys(person)  // ['age',Symbol(name)]

(5)用Symbol.for()创建全局变量

let sm1=Symbol.for('name');

let sm2=Symbol.for('name');

之前我们说过,在用Symbol创建变量时,即使描述相同,两个变量实际也是不同的(console.log(sm1===sm2)   //false  )。

但这里,我们用Symbol.for()来创建得到的结果是:

console.log(sm1===sm2)   //true

原因是:使用Symbol.for()来创建的symbol值被登记在全局环境中,以便用Symbol.for()来搜索。也就是使用Symbol创建的symbol值是无法用Symbol.for()来搜索的。

let sm1=Symbol('name');

let sm2=Symbol.for('name');

console.log(sm1===sm2)   //false

(6)Symbol.keyFor()  返回一个被登记在全局环境中的symbol值的key,没有返回undefined

let sm1=Symbol.for('name');

Symbol.keyFor('sm1')   //name

let sm1=Symbol('name');

Symbol.keyFor('sm1')   // undefined

ES6-Symbol的更多相关文章

  1. es6 Symbol类型

    es6 新增了一个原始类型Symbol,代表独一无二的数据 javascript 原来有6中基本类型, Boolean ,String ,Object,Number, null , undefined ...

  2. ES6 Symbol数据类型和set-map 数据结构

    Symbol数据类型 ES6新加的数据类型,提供一个独一无二的值 { let a1 = Symbol() ;let a2 = Symbol() } //声明 { let a3 = Symbol.for ...

  3. ES6 Symbol的应用场景

    一.简介 具体使用请参考:API ES6 引入了一种新的原始数据类型Symbol,表示独一无二的值.它是 JavaScript 语言的第七种数据类型,前六种是:undefined.null.布尔值(B ...

  4. ES6 symbol 以及symbol的简单应用

    前置 1.ES6 引入了一种新的原始数据类型Symbol,表示独一无二的值. 2.Symbol 值通过Symbol函数生成. 3.Symbol 函数可以接受一个字符串作为参数,表示对 Symbol 实 ...

  5. Es6 Symbol.iterator

    Symbol.iterator 为每一个对象定义了默认的迭代器.该迭代器可以被 for...of 循环结构使用. --描述 当需要迭代一个对象的时候(比如在 for...of 循环的开始时),它的 @ ...

  6. ES6——Symbol数据类型

    什么是 Symbol ? Symbol 表示独一无二的值,他是js中的 第七种数据类型. 基本的数据类型:null, undefined number boolean string symbol 引用 ...

  7. JavaScript ES6 Symbol.hasInstance的理解。

    Symbol.hasInstance 本案例是结合阮一峰老师的ECMAScript 6 入门丛书进一步的详细介绍,和对Symbol.hasInstance的理解.本着互联网的精神,分享给大家. 对象的 ...

  8. ES6 Symbol类型 附带:Proxy和Set

    七种数据类型 ·Symbol ·undefined ·null ·Boolean ·String ·Number ·Object let a = Symbol('this is a symbol'); ...

  9. 最新的JavaScript核心语言标准——ES6,彻底改变你编写JS代码的方式!【转载+整理】

    原文地址 本文内容 ECMAScript 发生了什么变化? 新标准 版本号6 兑现承诺 迭代器和for-of循环 生成器 Generators 模板字符串 不定参数和默认参数 解构 Destructu ...

  10. 深入浅出ES6(八):Symbols

    作者 Jason Orendorff  github主页  https://github.com/jorendorff 你是否知道ES6中的Symbols是什么,它有什么作用呢?我相信你很可能不知道, ...

随机推荐

  1. synergy配置 Ubuntu作Server, Win 7作client

    Synergy 允许你轻松地在你办公桌上多台计算机之间共享你的鼠标和键盘,它免费并且开放源代码.你只要将鼠标(指针)从一台计算机的屏幕边缘移出到另一个屏幕就行 了.甚至可以共享你的剪贴板.你所需要的仅 ...

  2. ubuntu php.ini文件位置

    mc@XJ > locate php.ini/etc/php5/cli/php.ini/etc/php5/fpm/php.ini

  3. Spring学习笔记之初始化和销毁方法的调用次序

    Multiple lifecycle mechanisms configured for the same bean, with different initialization methods, a ...

  4. SharePoint 列表应用实例 - 显示约束

    博客地址:http://blog.csdn.net/FoxDave 有时会碰到这样的需求,比如上传周报到文档库,周报只能领导和自己看到,其他同事是看不到的.通常我们开发的人遇到这种情况条件反射地想到的 ...

  5. Mac下SVN服务器环境的搭建和配置(除展示图片外,所有命令在Linux/Unix下适用)

    这几天领导没有安排工作,闲着没事就想把自己这两年做iOS开发时感觉知识有欠缺的地方想好好深入地补习一下,昨天和今天就计划好好学习下SVN和git的从创建和到原理,到命令,到界面的使用.一不小心被另一领 ...

  6. web api post传一个参数时 值永远是null

    这个问题纠结了我一个早上,不管用什么样的传参方法,走到控制器中,那个参数永远不变的等于null 在网上找了很多解决方案 上面这个是从网上截图的,第一:要将参数标记为[FromBody],变为简单参数 ...

  7. Zipper_DP

    Description Given three strings, you are to determine whether the third string can be formed by comb ...

  8. Unity3D 创建动态的立方体图系统

    Unity3D 创建动态的立方体图系统 这一篇主要是利用上一篇的Shader,通过脚本来完成一个动态的立方体图变化系统. 准备工作如下: 创建一个新的场景.一个球体.提供给场景一个平行光,准备2个立方 ...

  9. Magento导出订单同时导出产品信息

    Magento导出订单同时导出产品信息,根据业务扩展,Magento自身的功能也越来越满足不了我们的需求了.今天Hicoogle根据需求改善批量导出订单的同时,也要带上该订单的产品信息.花了一点时间, ...

  10. 第二个Sprint冲刺第十天

    讨论地点:宿舍 讨论成员:邵家文.李新.朱浩龙.陈俊金