我可以不用else来写if else吗?
var x=1;
x==2 ? dosomething() : doNothingButContinueCode();
我注意到,把null的其他工作(但我不知道为什么或如果这是一个好主意)。
编辑:你们中的一些人似乎很困惑,为什么我要费心去尝试这个。放心,这纯粹是出于好奇。我喜欢摆弄JavaScript。
我可以不用else来写if else吗?
var x=1;
x==2 ? dosomething() : doNothingButContinueCode();
我注意到,把null的其他工作(但我不知道为什么或如果这是一个好主意)。
编辑:你们中的一些人似乎很困惑,为什么我要费心去尝试这个。放心,这纯粹是出于好奇。我喜欢摆弄JavaScript。
当前回答
另一个选择:
x === 2 ? doSomething() : void 0;
其他回答
如果你不做其他的,为什么不做:
if (x==2) doSomething();
可能是最短的(基于OR运算符及其优先级)
x-2||dosomething()
设x=1, y=2; Let dosomething = console.log; x-2||dosomething('x dosomething '); y-2||dosomething('y dosomething ');
一个小的添加到这个老线程..
如果你在for/while循环中用三元操作符求值一个表达式,并希望结果是continue或break——你会遇到问题,因为continue和break都不是表达式;它们是没有任何值的语句。
这将产生Uncaught SyntaxError: Unexpected令牌继续
for (const item of myArray) {
item.value ? break : continue;
}
如果你真的想要一个返回语句的一行程序,你可以使用这个:
for (const item of myArray) {
if (item.value) break; else continue;
}
附注:这段代码可能会引起一些质疑。只是说. .:)
另一个选择:
x === 2 ? doSomething() : void 0;
这也是一个选项:
x==2 && dosomething();
Dosomething()只在x==2被赋值为true时才会被调用。这叫做短路。
它在这种情况下不常用,你真的不应该写这样的代码。我鼓励这种更简单的方法:
if(x==2) dosomething();
你应该始终编写可读的代码;如果你担心文件的大小,只需在众多JS压缩器的帮助下创建一个缩小版本。(例如谷歌的闭包编译器)