es6 Symbol iterator接口

简介: es6 Symbol iterator接口

Symbol定义:一种新的原始数据类型,表示独一无二的值,是一种类似字符串的数据类型


特点:


值是唯一的,用来解决命名冲突的问题


值不能与其他数据进行运算


注意点


Symbol 值作为属性名时,该属性是公有属性不是私有属性,可以在类的外部访问。但是不会出现在 for...in 、 for...of 的循环中,也不会被 Object.keys() 、 Object.getOwnPropertyNames() 返回。如果要读取到一个对象的 Symbol 属性,可以通过 Object.getOwnPropertySymbols() 和 Reflect.ownKeys() 取到。

// 创建Symbol()
let s = Symbol();
let s2= Symbol('小红')
let s3= Symbol('小红')
consle.log(s2===s3) //false
//Symbol.for创建
let s4 =Symbol.for('小明');
let s5 =Symbol.for('小明');
console.log(s4===s4)  //true
//不能与其他数据进行运算
let result= s+100 // 报错
// 使用场景
 let up = Symbol('say');
    let game = {
      up: '1111',
      [up]: function () {
        console.log('我可以发言')
      },
      [Symbol('down')]: function () {
        console.log('我可以下降')
      }
    }
console.log(game)


symbol.for()


Symbol.for() 类似单例模式,首先会在全局搜索被登记的 Symbol 中是否有该字符串参数作为名称的 Symbol 值,如果有即返回该 Symbol 值,若没有则新建并返回一个以该字符串参数为名称的 Symbol 值,并登记在全局环境中供搜索。

let yellow = Symbol("Yellow");
let yellow1 = Symbol.for("Yellow");
yellow === yellow1;      // false
let yellow2 = Symbol.for("Yellow");
yellow1 === yellow2;     // true


Symbol.keyFor()


Symbol.keyFor() 返回一个已登记的 Symbol 类型值的 key ,用来检测该字符串参数作为名称的 Symbol 值是否已被登记。

let yellow1 = Symbol.for("Yellow");
Symbol.keyFor(yellow1);    // "Yellow"


Symbol 内置值(扩展对象功能的)



迭代器(Iterator

就是对象里的属性


主要供for...of 遍历 键值

let xiyou=['唐僧','孙悟空','猪八戒','沙僧']
遍历数据工作原理  
// 创建指针独享,指向当前数据 结构的起始位置
let iterator = xiyou[Symbol.iterator]();
// 调用对象的next方法
   第一次调用next方法,指针自动指向数据结构的第一个成员
    接下来不断调用next方法,指针一直往后移动,直到指向最后一个成员
    每调用next方法返回一个包含value和dine属性的对象
console.log(iterator.next())    //{value:'唐僧',done:false}
console.log(iterator.next())    //{value:'孙悟空',done:false}
console.log(iterator.next())    //{value:'猪八戒',done:false}
console.log(iterator.next())    //{value:'沙僧',done:false}
console.log(iterator.next())    //undefined{value:undefined,done:false}
相关文章
|
6月前
|
JavaScript 前端开发
ES6:什么是Symbol?
ES6:什么是Symbol?
78 1
|
6月前
ES6之Symbol
ES6之Symbol
|
6月前
|
JavaScript 前端开发
|
14天前
|
设计模式 JavaScript 前端开发
es6加上symbol的基础数据类型
【10月更文挑战第30天】ES6 中的 `Symbol` 作为一种新的基础数据类型,为 JavaScript 提供了一种创建唯一标识符和处理对象属性名冲突的有效方式,丰富了 JavaScript 的数据类型体系和编程模式,在实际开发中具有重要的应用价值。
|
14天前
|
设计模式 JavaScript 前端开发
es6加上symbol的基础数据类型
【10月更文挑战第22天】ES6中的 `Symbol` 作为一种新的基础数据类型,为JavaScript提供了一种创建唯一标识符和处理对象属性名冲突的有效方式,丰富了JavaScript的数据类型体系和编程模式,在实际开发中具有重要的应用价值。
|
4月前
|
存储 JavaScript 前端开发
JavaScript编码之路【ES6新特性之 Symbol 、Set 、Map、迭代器、生成器】(二)
JavaScript编码之路【ES6新特性之 Symbol 、Set 、Map、迭代器、生成器】(二)
54 1
|
4月前
|
存储 JavaScript 前端开发
JavaScript编码之路【ES6新特性之 Symbol 、Set 、Map、迭代器、生成器】(一)
JavaScript编码之路【ES6新特性之 Symbol 、Set 、Map、迭代器、生成器】(一)
39 0
|
6月前
|
存储 JavaScript
ES6+新特性-Symbol与Set/Map数据结构
ES6 引入了三种新的数据结构:Symbol、Set和Map。Symbol是唯一且不可变的值,常用于定义对象的独特属性;Set存储不重复值,适合数组去重;Map则是键值对集合,键可为任意类型,提供了更灵活的存储方式。这些新数据结构提供了更高效的操作手段,分别解决了属性命名冲突、数据去重和复杂键值对存储的问题。示例展示了如何使用Symbol、Set和Map进行基本操作。
|
6月前
|
JavaScript
js开发:请解释什么是ES6的Symbol,以及它的用途。
ES6的Symbol数据类型创建唯一值,常用于对象属性键(防冲突)和私有属性。示例展示了如何创建及使用Symbol:即使描述相同,两个Symbol也不等;作为对象属性如`obj[symbol1] = 'value1'`;也可作枚举值,如`Color.RED = Symbol('red')`。
54 4