ES6-Symbol
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的更多相关文章
- es6 Symbol类型
es6 新增了一个原始类型Symbol,代表独一无二的数据 javascript 原来有6中基本类型, Boolean ,String ,Object,Number, null , undefined ...
- ES6 Symbol数据类型和set-map 数据结构
Symbol数据类型 ES6新加的数据类型,提供一个独一无二的值 { let a1 = Symbol() ;let a2 = Symbol() } //声明 { let a3 = Symbol.for ...
- ES6 Symbol的应用场景
一.简介 具体使用请参考:API ES6 引入了一种新的原始数据类型Symbol,表示独一无二的值.它是 JavaScript 语言的第七种数据类型,前六种是:undefined.null.布尔值(B ...
- ES6 symbol 以及symbol的简单应用
前置 1.ES6 引入了一种新的原始数据类型Symbol,表示独一无二的值. 2.Symbol 值通过Symbol函数生成. 3.Symbol 函数可以接受一个字符串作为参数,表示对 Symbol 实 ...
- Es6 Symbol.iterator
Symbol.iterator 为每一个对象定义了默认的迭代器.该迭代器可以被 for...of 循环结构使用. --描述 当需要迭代一个对象的时候(比如在 for...of 循环的开始时),它的 @ ...
- ES6——Symbol数据类型
什么是 Symbol ? Symbol 表示独一无二的值,他是js中的 第七种数据类型. 基本的数据类型:null, undefined number boolean string symbol 引用 ...
- JavaScript ES6 Symbol.hasInstance的理解。
Symbol.hasInstance 本案例是结合阮一峰老师的ECMAScript 6 入门丛书进一步的详细介绍,和对Symbol.hasInstance的理解.本着互联网的精神,分享给大家. 对象的 ...
- ES6 Symbol类型 附带:Proxy和Set
七种数据类型 ·Symbol ·undefined ·null ·Boolean ·String ·Number ·Object let a = Symbol('this is a symbol'); ...
- 最新的JavaScript核心语言标准——ES6,彻底改变你编写JS代码的方式!【转载+整理】
原文地址 本文内容 ECMAScript 发生了什么变化? 新标准 版本号6 兑现承诺 迭代器和for-of循环 生成器 Generators 模板字符串 不定参数和默认参数 解构 Destructu ...
- 深入浅出ES6(八):Symbols
作者 Jason Orendorff github主页 https://github.com/jorendorff 你是否知道ES6中的Symbols是什么,它有什么作用呢?我相信你很可能不知道, ...
随机推荐
- ubuntu连接Android调试
从这周开始尝试Android开发,记下点滴. 安装JDK.下载ADT不说,连接手机调试的时候出错,一堆问号??????????.网上一查,属于典型错误.试下来,有几步比较关键,容易忽视: 1.我机器上 ...
- getBoundingClientRect() 来获取页面元素的位置
getBoundingClientRect() 来获取页面元素的位置 document.documentElement.getBoundingClientRect 下面这是MSDN的解释: Syn ...
- [vijos P1034] 家族
寒假给自己定的第一个目标就是把并查集,Tarjan之类搞会.翻了翻笔记,发现并查集是2012年的6月30日学的…早就忘光了…今天敲题目的时候也吃了不少的亏呢… 家族这一题就是并查集的标准题,第一次提交 ...
- English idioms
a hot potato : speak of an issue(mostly current) which many people are talking about and which is us ...
- 【转】CentOS yum安装和卸载软件的使用方法
在CentOS yum安装和卸载软件的使用方法安装方法安装一个软件时. CentOS yum -y install httpd安装多个相类似的软件时 CentOS yum -y install ...
- jQuery dialog 简介
dialog是jQuery UI 库的一个UI组件,所以使用dialog时,不仅要引入jQuery.js(因为它只是轻量级的基础框架),还需要引入jQueryUI的js及相关css文件 示例: < ...
- JavaScript 时间特效 显示当前时间
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...
- C# 启动关闭.exe进程(转)
后台代码: 1 using System.Diagnostics; 2 3 protected void Button1_Click(object sender, EventArgs e)4 ...
- 《java笔记 day07》
//匿名对象_1 class Car { //描述属性: String color; int number; //描述行为: void run() { System.out.println(color ...
- 深入理解SELinux
目录(?)[+] 1. 简介 SELinux带给Linux的主要价值是:提供了一个灵活的,可配置的MAC机制. Security-Enhanced Linux (SELinux)由以下两部分组 ...