Javascript这行代码是什么意思

Javascript what does this line of code mean

本文关键字:是什么 意思 代码 Javascript      更新时间:2023-09-26

我在学习Javascript,但不知道为什么这一行是这样写的。 有人可以帮助解释为什么javascript要写这样的代码吗?

cinnamon && (this.cinnamon = [1, "stick", "Saigon"])是什么意思?
我明白它上面的第一行。 第二行似乎在做一个比较运算符 &&,但没有将其分配给任何变量。

      var VanillaBean = function(vanilla, cinnamon) {
      this.vanilla = [1, "bean", vanilla ? vanilla : "Madagascar Bourbon"];
      cinnamon && (this.cinnamon = [1, "stick", "Saigon"]);  //?????
    };
    VanillaBean.prototype = {
      heavyCream: [1, "cup", "Organic Valley"],
      halfHalf: [2, "cup", "Organic Valley"],
      sugar: [5/8, "cup"],
      yolks: [6]
    };
    var vanilla = new VanillaBean("Tahitian", true);
    console.dir(vanilla);

行:

cinnamon && (this.cinnamon = [1, "stick", "Saigon"]);

相当于:

if (cinnamon) {
    this.cinnamon = [1, "stick", "Saigon"];
}

逻辑AND运算符的短路特性有时以这种方式使用,因为生成的代码比完整的if语句短。

也就是说,我个人不鼓励编写这样的代码,因为它的可读性和可维护性不如if语句。

逻辑 && 运算符是"lazy"的,如果第一个表达式为真,它只计算第二个表达式。 它相当于if(cinnamon){ this.cinnamon=[...];}

类似地,cinnamon || this.cinnamon=[...];等效于if(!cinnamon){this.cinnamon=[...];},因为当您计算 OR 时,仅当第一个表达式为 false 时,才需要测试(并因此执行)第二个表达式。从补语中最好理解:

(false && anything)=false,所以不要费心执行第二个套件

(true || anything)=true,所以不要费心执行第二个套件