es6中的generator函数详解,前端开发工程师面试题

本文详细介绍了Generator函数的概念,包括其定义、工作原理、yield表达式的使用、next方法的作用以及与普通函数和Promise、async/await的关系。重点阐述了Generator在异步编程中的优势和使用场景。
摘要由CSDN通过智能技术生成

什么是Generator函数

  1. function 关键字和函数之间有一个星号(*),且内部使用yield表达式,定义不同的内部状态。
  1. 调用Generator函数后,该函数并不执行,返回的也不是函数运行结果,而是一个指向内部状态的指针对象。

function fn(){ // 定义一个Generator函数

yield ‘hello’;

yield ‘world’;

return ‘end’;

}

var f1 =fn(); // 调用Generator函数

console.log(f1); // fn {[[GeneratorStatus]]: “suspended”}

console.log(f1.next()); // {value: “hello”, done: false}

console.log(f1.next()); // {value: “world”, done: false}

console.log(f1.next()); // {value: “end”, done: true}

console.log(f1.next()); // {value: undefined, done: true}

但是,调用Generator函数后,函数并不执行,返回的也不是函数执行后的结果,而是一个指向内部状态的指针对象。

下一步,必须调用遍历器对象的next方法,使得指针移向下一个状态。即:每次调用next方法,内部指针就从函数头部或上一次停下来的地方开始执行,直到遇到下一个yield表达式(或return语句)为止。

Generator 函数是分段执行的,yield表达式是暂停执行的标记,而next方法可以恢复执行。

如下案例:

function* gen(x){//一个 Generator 函数

console.log(‘x=’+x)

var y = yield x + 2;

return y;

}

//调用Generator 函数

var g = gen(1);

g.next();

输出:x=1

{value: 3, done: false}

注意:调用g.next() 即执行异步任务的 x+2

  • next 方法的作用是分阶段执行 Generator 函数。每次调用 next 方法,会返回一个对象,表示当前阶段的信息( value 属性和 done 属性)。

  • value 属性是 yield 语句后面表达式的值,表示当前阶段的值;

  • done 属性是一个布尔值,表示 Generator 函数是否执行完毕,即是否还有下一个阶段(done为false 继续执行)。

Generator 函数的数据交换

function* gen(x){

var y = yield x + 2;

return y;

}

var g = gen(1);

//第一次执行

g.next() // { value: 3, done: false }

//第二次执行 时,如果有带参数,

这个参数可以传入 Generator 函数,作为上个阶段异步任务的返回结果,被函数体内的变量 y 接收。

g.next(2) // { value: 2, done: true }

因此,这一步的 value 属性,返回的就是2(变量 y 的值)。

//如果没带参数

g.next() //{value: undefined, done: true}

1.迭代器协议: 定义了一种标准的方式来产生一个有限或无限序列的值;

当一个对象被认为是一个迭代器时,它实现了一个 next() 的方法,next()返回值如下:

{

done:true,//false迭代是否结束,

value:v,//迭代器返回值

}

2.generator的用途:

在JavaScript中,一个函数一旦被执行,就会执行到最后或者被return,运行期间不会被外部所影响打断,而generator的出现就打破了这种函数运行的完整性。

3.generator函数与普通函数的区别:

a.function关键字与函数名中间有一个*键

b.Generator函数使用了yield表达式

c. 直接调用 Generator函数并不会执行,也不会返回运行结果,而是返回一个遍历器对象(Iterator Object)

d.调用Generator函数时需用到next(),如果有多个yield状态,要依次调用next()

e.该生成器函数执行后会返回一个Iterator对象,对象内有yield的返回值,以及还有一个状态done的属性(该属性表示当前生成器内yield表达式全部执行完毕,执行完毕返回true)

{

done:true,//false迭代是否结束,

value:v,//迭代器返回值

}

4.generator函数的语法:

// 传统函数

function foo() {

return ‘hello world’

}

foo() // ‘hello world’,一旦调用立即执行

//Generator函数

function* persition(){

yield ‘我是generato生成器’;

yield ‘我要开始了’;

return ‘结束’

}

//创建一个句柄,赋值给生成器

var iterator =persition();

//直接调用并不能被立即执行

console.log(iterator)

//需使用next()方法来调用这个生成器 next()方法调用一次,

//并不能将Generator函数内的yield值全部打印出来,需要依次进行调用

console.log(iterator.next())

console.log(iterator.next())

//如果iterator对象内done为true,证明Generator函数执行完毕

console.log(iterator.next())

5.yield表达式:

yield 表达式只能用在 Generator 函数里面,用在其它地方都会报错

function(){

yield 1;

}

// SyntaxError: Unexpected number

// 在一个普通函数中使用yield表达式,结果产生一个句法错误

}

6.next():

generator函数(生成器)调用的唯一方法,且注意需依次调用next方法,

对于普通的生成器,第一次next调用,相当于启动生成器,会从生成器函数的第一行代码开始执行,直到第一次执行完yield语句后,跳出生成器函数。

然后第二个next调用,进入生成器函数后,从yield语句的下一句语开始执行,然后重新运行到yield语句,执行后,跳出生成器函数,

promise generator aysnc/await


1.三者都是异步编程的解决方案,不同的是,promise为较早出来的,其次generator,最后为async/await,三者象征了前端进行解决异步编程的进化路程。

promise:


promise比较简单,也是最常用的,主要就是将原来用 回调函数异步编程的方法 转成 relsove和reject触发事件;

对象内含有四个方法,then()异步请求成功后

catch()异步请求错误的回调方法

finally()请求之后无论是什么状态都会执行

resolve()将现有对象转换为Promise对象

all()此方法用于将多个Promise实例包装成一个新的promise实例。

race()也是将多个Promise实例包装成一个新的promise实例

reject()返回一个状态为Rejected的新Promise实例。

有点:让回调函数变成了规范的链式写法,程序流程可以看的很清楚

缺点:编写的难度比传统写法高,阅读代码也不是一眼可以看懂

Generator:


generator是一个迭代生成器,其返回值为迭代器(lterator),是ES6标准引入的新的数据类型,主要用于异步编程,它借鉴于Python中的generator概念和语法;

generator函数内有两个重要方法,1 yield表达式 2.next()

Generator 函数是分段执行的,yield表达式是暂停执行的标记,而 next方法可以恢复执行

优点:1.利用循环,每调用一次,就使用一次,不占内存空间 2.打破了普通函数执行的完整性

缺点: 需要用next()方法手动调用,直接调用返回无效iterator 2.

async/await:


async:异步函数

await:同步操作

es7中提出来的异步解决方法,是目前解决异步编程终它基极解决方案,于promise为基础,其实也就是generator的高级语法糖,本身自己就相当于一个迭代生成器(状态机),它并不需要手动通过next()来调用自己,与普通函数一样

async就相当于generator函数中的*,await相当于yield,

async 用于申明一个 function 是异步的,而 await 用于等待一个异步方法执行完成。

function getSomething() {

return “something”;

}

async function testAsync() {

return Promise.resolve(“hello async”);

}

async function test() {

//await是在等待一个async函数完成

const v1 = await getSomething();

//await后面不仅可以接Promise,还可以接普通函数或者直接量

const v2 = await testAsync();

console.log(v1, v2);

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

结尾

正式学习前端大概 3 年多了,很早就想整理这个书单了,因为常常会有朋友问,前端该如何学习,学习前端该看哪些书,我就讲讲我学习的道路中看的一些书,虽然整理的书不多,但是每一本都是那种看一本就秒不绝口的感觉。

以下大部分是我看过的,或者说身边的人推荐的书籍,每一本我都有些相关的推荐语,如果你有看到更好的书欢迎推荐呀。

戳这里免费领取前端学习资料

化!**

[外链图片转存中…(img-BvI8hoKz-1712099260572)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

结尾

正式学习前端大概 3 年多了,很早就想整理这个书单了,因为常常会有朋友问,前端该如何学习,学习前端该看哪些书,我就讲讲我学习的道路中看的一些书,虽然整理的书不多,但是每一本都是那种看一本就秒不绝口的感觉。

以下大部分是我看过的,或者说身边的人推荐的书籍,每一本我都有些相关的推荐语,如果你有看到更好的书欢迎推荐呀。

戳这里免费领取前端学习资料

前端学习书籍导图-1

  • 17
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值