博客
关于我
Generator中的yield和next
阅读量:735 次
发布时间:2019-03-21

本文共 759 字,大约阅读时间需要 2 分钟。

yield语句本身没有返回值

在JavaScript中,Generator函数的`yield`语句本身并不会返回任何值。这一点对理解代码的行为至关重要。

var b = 9;var a = function*() {    	b = yield(10);	/*	* 将yield语句拆分为两个独立步骤来理解:	* yield(10)本身不会返回值,所以b的值将是undefined。*/	return 11;}

我们可以通过以下代码示例来理解这一点:

var f = a();console.log(f.next().value, b, f.next().value, b);

这个代码会输出:undefined, undefined, 11, undefined

传入的参数如何影响结果的覆盖

在Generator函数中,当你调用`next()`方法传入参数时,这实际上会影响`yield`语句的执行。传入的参数会被用于替换`yield`后的表达式的结果。

var b = 9;var a = function*() {    		b = yield(10);		/*	* 将yield语句拆分为两个独立步骤来理解:	* yield(10)本身不会返回值,但下一个`next()`传入的参数会覆盖b的值。*/		return 11;	}	var f = a();	console.log(f.next().value, b, f.next(13).value, b);

这个代码会输出:10, 9, 11, 13

这意味着,当你在Generator函数中使用`yield`语句时,后续的`next()`方法传入的参数会覆盖之前的`yield`结果。因此,在我们的示例中,`b`的最终值会被更新为13,而不是最初的9。

转载地址:http://jvtgz.baihongyu.com/

你可能感兴趣的文章
mysql登陆慢问题解决
查看>>
MySQL的 DDL和DML和DQL的基本语法
查看>>
mysql的 if else , case when then, IFNULL
查看>>
MySQL的10种常用数据类型
查看>>
MySQL的btree索引和hash索引的区别
查看>>
mysql的cast函数
查看>>
MySql的CRUD(增、删、改、查)操作
查看>>
MySQL的DATE_FORMAT()函数将Date转为字符串
查看>>
MySql的Delete、Truncate、Drop分析
查看>>
MySQL的Geometry数据处理之WKB方案
查看>>
MySQL的Geometry数据处理之WKT方案
查看>>
mysql的grant用法
查看>>
Mysql的InnoDB引擎的表锁与行锁
查看>>
mysql的InnoDB引擎索引为什么使用B+Tree
查看>>
MySQL的InnoDB默认隔离级别为 Repeatable read(可重复读)为啥能解决幻读问题?
查看>>
MySQL的insert-on-duplicate语句详解
查看>>
mysql的logrotate脚本
查看>>
MySQL的my.cnf文件(解决5.7.18下没有my-default.cnf)
查看>>
MySQL的on duplicate key update 的使用
查看>>
MySQL的Replace用法详解
查看>>