ES6——Symbol数据类型
来源:互联网 发布:淘宝分流比例设置 编辑:程序博客网 时间:2024/06/07 00:37
作用
声明独一无二的变量
两个Symbol是不相等的。
let a1 = Symbol(); //不用newlet a2 = Symbol();console.log(a1===a2); //false
防止key值冲突
let a1=Symbol.for('abc');let obj={ [a1]:'123', 'abc':345, 'c':456};console.log('obj',obj); // {abc: 345, c: 456, Symbol(abc): "123"}
[a1]就是上面的Symbol,它的key值是’abc’,
而下面也有一个key值是’abc’,但是不冲突。
方法
Symbol.for() 查找key值
这种方法会在全局搜索key值,
如果有,就返回值;
如果没有,就会生成key值。
let a3=Symbol.for('a3'); //声明keylet a4=Symbol.for('a3'); //找到变量a3对应的key值console.log(a3===a4); //a3 === a3
Object.getOwnPropertySymbols() 获取value
它只能拿到Symbol()的value值,拿不到普通属性的value值
返回值:数组
实例
let s5 = Symbol('s5');let s6 = Symbol('s6');let a = { [s5]: 'rs5', [s6]: 'rs6'}Object.getOwnPropertySymbols(a).forEach(function(item){ console.log(a[item]); // rs5 rs6})
Reflect.ownKeys() 获取key和value
可以拿到Symbol()和非Symbol的key值、value值
返回值:数组
实例
let s5 = Symbol('s5');let s6 = Symbol('s6');let a = { [s5]: 'rs5', [s6]: 'rs6'}Reflect.ownKeys(a).forEach(function(item){ console.log(item,a[item]); // Symbol(s5) "rs5" Symbol(s6) "rs6"})
阅读全文
0 0
- ES6——Symbol数据类型
- 8、Symbol数据类型—ES6学习笔记
- ES6 — Symbol
- es6 javascript Symbol数据类型
- ES6新数据类型 Symbol
- ES6新数据类型Symbol
- ES6--Symbol数据类型
- js-es6-Symbol新增的数据类型
- ES6学习——新的语法:Symbols——Symbol.toPrimitive,Symbol.hasInstance,Symbol.toStringTag,Symbol.species
- ES6学习——新的语法:Symbol概述
- ES6学习——新的语法:Symbol API介绍
- ES6必知必会 —— Symbol、Set和Map
- ES6--Symbol
- ES6 symbol
- 【ES6】symbol
- es6-symbol
- ES6--symbol
- 【es6】symbol
- Struts2的跳转
- FTPrep, 91 Decode Ways, TODO: need to repeat and conclude
- A33 Vstar开发板简述及BSP下载
- Android studio 常用快捷键
- Blog1@linux 基本命令介绍(一)
- ES6——Symbol数据类型
- JDBC日期字段
- HTML5添加了utf-8中文还是乱码
- 50行头文件+宏:acm专用 -- 初级版
- [BZOJ1925][SDOI2010]地精部落-动态规划
- JSTL详解
- Android TV 官方教程简读3-Building Layouts for TV
- python爬取京东商品信息
- DOM操作