由一段小代码引发的关于“表达式”和“语句”的探讨

534 阅读1分钟

本文摘自我在《知识星球》今天的分享,点击文章后面的查看原文可以加入我的星球(是需要付费的)。

今天有人群里发了一段代码

  1. let foo = {};

  2. foo[foo['red'] = 1] = 'red';

并感慨道:

才发现 js 还可以这样写。。

我不知道他为啥如此感慨,遂追问了一句,他的回答是:

以前不知道赋值操作还有返回值。


听到这个回复我,我就大概知道了。他可能看了二手的文档了,或者是没有系统的学习。

因为在正式文档中,是不会使用赋值“操作”这个词的。而是使用表达式和语句。

赋值“表达式”都有返回值(任何表达式都有返回值),但是赋值“语句”没有。

b=5 是赋值表达式,返回值是  5,所以我们可以写:

                            
  1. var a = (b = 5); // ok

但是 varb=5 是个赋值语句,所以我们不能写:

                                
  1. var a = (var b = 5 ); // error

会抛出异常: UncaughtSyntaxError:Unexpectedtokenvar

同理, if 是语句,所以我们不能写:

                                        
  1. var a = if(true ) { }

也是类似的异常: UncaughtSyntaxError:Unexpectedtokenif


你可能觉得:我当然知道 if 不能赋值给一个变量了!!!

但是~~~~

在某些语言,尤其是函数式编程语言中,if-else 也是语句。很多函数式编程语言的卖点就是只有表达式,没有语句。

比如 Kotlin 中,你可以这么写:

  1. val max = if (a > b) a else b

因为它的 if(a>b)aelseb 是表达式,有返回值,所以可以直接赋值给  max