首页 > 其他分享 >万象更新 Html5 - es6 进阶: iterator, generator

万象更新 Html5 - es6 进阶: iterator, generator

时间:2024-09-24 11:47:56浏览次数:12  
标签:es6 console generator iterator 万象更新 value next done yield

源码 https://github.com/webabcd/Html5
作者 webabcd

万象更新 Html5 - es6 进阶: iterator, generator

示例如下:

es6\src\advanced\iterator_generator.js

/**
 * iterator - 迭代器(可迭代对象有 Array, TypedArray, Map, Set, String)
 *   next() - 迭代到下一个位置
 *     value - 当前位置的对象
 *     done - 当前位置是否是结尾
 *       true 代表结尾,也就是说,可迭代对象的最后一个元素的 done 仍然为 false,再之后才是 true
 */

const a = ["a", "b", "c"];
// [Symbol.iterator]() - 获取可迭代对象的迭代器
const b = a[Symbol.iterator]();
console.log(b.next(), b.next(), b.next(), b.next());
// {value: "a", done: false} {value: "b", done: false} {value: "c", done: false} {value: undefined, done: true}


// 通过 for...of 语句迭代可迭代对象(es6 中新增的方式)
let c = ["a", "b", "c"];
for (let item of c) {
    console.log(item);
}
// a
// b
// c


// 用其他方式遍历(es5 中就有的方式)
for (let i = 0; i < c.length; i++) { // for 语句
    console.log(c[i]);
}
// a
// b
// c
for (let index in c) { // for...in 语句
    console.log(index, c[index]);
}
// 0 a
// 1 b
// 2 c
c.forEach(item => { // forEach 语句
    console.log(item);
});
// a
// b
// c




/**
 * Generator - 自定义可迭代对象,即可以支持 iterator 的对象
 *   通过 function* 定义生成器函数(generator function)
 *   每 next() 一下得到的是 generator function 的下一个 yield 的值
 *   yield 的返回值是此 yield 之后再次 next() 传进来的值
 *   如果 next() 后遇到了 return 则迭代结束,返回的 value 是 return 的值,得到的 done 为 true
 */
function* generator() {
    let x = yield 1;
    console.log(`x:${x}`);
    let y = yield 2;
    console.log(`y:${y}`);
    if (x == undefined || y == undefined) {
        return 3;
    } else {
        return x + y;
    }
}
let g1 = generator();
console.log(g1.next(), g1.next(), g1.next());
// x:undefined
// y:undefined
// {value: 1, done: false} {value: 2, done: false} {value: 3, done: true}
let g2 = generator();
console.log(g2.next(10), g2.next(20), g2.next(30));
// x:20
// y:30
// {value: 1, done: false} {value: 2, done: false} {value: 50, done: true}


// 通过 yield* 在一个 function* 内调用另一个 function*
function* generator_b() {
    yield 2;
    yield 3;
}
function* generator_a() {
    yield 1;
    yield* generator_b();
    return undefined;
}
let ga = generator_a();
console.log(ga.next(), ga.next(), ga.next(), ga.next());
// {value: 1, done: false} {value: 2, done: false} {value: 3, done: false} {value: undefined, done: true}


// 以下为 generator 和 iterator 的应用:通过 generator 将一个对象变为支持 iterator 的对象
function* objectEntries(obj) {
    const propKeys = Reflect.ownKeys(obj);
    for (const propKey of propKeys) {
        yield [propKey, obj[propKey]];
    }
}
let obj = { name: "webabcd", age: 40 };
for (const [key,value] of objectEntries(obj)) {
    console.log(`${key}: ${value}`);
}
// name: webabcd
// age: 40

源码 https://github.com/webabcd/Html5
作者 webabcd

标签:es6,console,generator,iterator,万象更新,value,next,done,yield
From: https://www.cnblogs.com/webabcd/p/18428833/html5_es6_src_advanced_iterator_generator

相关文章

  • 万象更新 Html5 - es6 进阶: proxy, reflect
    源码https://github.com/webabcd/Html5作者webabcd万象更新Html5-es6进阶:proxy,reflect示例如下:es6\src\advanced\proxy_reflect.js//Proxy-代理(拦截目标对象的属性操作和函数操作)lettarget={name:'webabcd',age:40,gethello(){......
  • 万象更新 Html5 - es6 进阶: 编译和压缩
    源码https://github.com/webabcd/Html5作者webabcd万象更新Html5-es6进阶:编译和压缩示例如下:es6\src\index.html<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>es6</title><......
  • 万象更新 Html5 - es6 进阶: ArrayBuffer
    源码https://github.com/webabcd/Html5作者webabcd万象更新Html5-es6进阶:ArrayBuffer示例如下:es6\src\advanced\arrayBuffer.js/***1、ArrayBuffer-内存之中的一段二进制数据,需要通过视图操作数据*2、TypedArray-视图,用于操作ArrayBuffer对象,TypedArr......
  • 万象更新 Html5 - es6 进阶: promise
    源码https://github.com/webabcd/Html5作者webabcd万象更新Html5-es6进阶:promise示例如下:es6\src\advanced\promise.js/***Promise-用于异步编程(非多线程)*有3种状态:pending(进行中),fulfilled(已成功),rejected(已失败)*状态只能从pending变为fulfil......
  • 万象更新 Html5 - es6 进阶: async/await
    源码https://github.com/webabcd/Html5作者webabcd万象更新Html5-es6进阶:async/await示例如下:es6\src\advanced\async_await.js/***async/await-用于异步编程(非多线程)*asyncfunction返回的是Promise对象*await用于等Promise对象或者thenab......
  • 万象更新 Html5 - vue.js: vue 指令(自定义指令)
    源码https://github.com/webabcd/Html5作者webabcd万象更新Html5-vue.js:vue指令(自定义指令)示例如下:vue\directive\vcustom.html<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>vue指令(自定......
  • 万象更新 Html5 - vue.js: vue 组件 1
    源码https://github.com/webabcd/Html5作者webabcd万象更新Html5-vue.js:vue组件1示例如下:vue\component\sample1.html<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>vue组件1</t......
  • 万象更新 Html5 - vue.js: vue 组件 2
    源码https://github.com/webabcd/Html5作者webabcd万象更新Html5-vue.js:vue组件2示例如下:vue\component\sample2.html<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>vue组件2</t......
  • 万象更新 Html5 - vue.js: vue 路由基础
    源码https://github.com/webabcd/Html5作者webabcd万象更新Html5-vue.js:vue路由基础示例如下:vue\router\sample1.html<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>vue路由基础</titl......
  • 万象更新 Html5 - es6 基础: var, let, const
    源码https://github.com/webabcd/Html5作者webabcd万象更新Html5-es6基础:var,let,const示例如下:es6\src\basic\var_let_const.js//let仅在代码块内有效{leta=100;console.log(a);}{leta=100;console.log(a);}//const常量,......