相思资源网 Design By www.200059.com

有一道js面试题,题目是这样的:下列代码的执行结果是什么,为什么?
复制代码 代码如下:
var i, j, k;
for (i=0, j=0; i<10, j<6; i++, j++) {
  k = i+j;
}
document.write(k);

答案是显示10,这道题主要考察JavaScript的逗号运算符。

下面是MDN对逗号运算符的定义:

逗号运算符计算两个操作数(从左至右)并返回第二个操作数的值。

根据这个定义,可以扩展一下:

逗号运算符从左到右计算两个或多个操作数并返回最后一个操作数的值。

可以感觉一下下面的代码:
复制代码 代码如下:
alert((0, 9));
alert((9, 0));

if (0,9) alert("ok");
if (9,0) alert("ok");

逗号运算符在实际代码中有什么样的作用呢?

1、交换变量,无需第三个变量
复制代码 代码如下:
var a = "a", b = "b";

//方法一
a = [b][b = a, 0];

//方法二
a = [b, b = a][0];

2、简化代码
复制代码 代码如下:
if(x){
  foo();
  return bar();
}
else{
  return 1;
}

可以简写成:

复制代码 代码如下:
return x ? (foo(), bar()) : 1;

标签:
JavaScript,逗号运算符

相思资源网 Design By www.200059.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
相思资源网 Design By www.200059.com

评论“JavaScript中逗号运算符介绍及使用示例”

暂无JavaScript中逗号运算符介绍及使用示例的评论...