是否有一个真正简单的方法来切换一个布尔值在javascript?
到目前为止,除了编写自定义函数之外,我得到的最好的方法是三元函数:
bool = bool ? false : true;
是否有一个真正简单的方法来切换一个布尔值在javascript?
到目前为止,除了编写自定义函数之外,我得到的最好的方法是三元函数:
bool = bool ? false : true;
如果您不介意将布尔值转换为数字(即0或1),则可以使用按位异或赋值操作符。像这样:
bool ^= true; //- toggle value.
let inDynamicEditMode = true; // Value is: true (boolean)
inDynamicEditMode ^= true; // Value is: 0 (number)
inDynamicEditMode ^= true; // Value is: 1 (number)
inDynamicEditMode ^= true; // Value is: 0 (number)
对我来说,这比在每行中重复变量更容易扫描。
此方法适用于所有(主要)浏览器(和大多数编程语言)。
让我们来看看实际情况:
Var b = true; console.log (b);/ /正确的 B = ! console.log (b);/ /错误 B = ! console.log (b);/ /正确的
无论如何,没有比你现在拥有的更短的路了。
在你可能将true / false存储为字符串的情况下,例如在localStorage中,协议在2009年翻转为多对象存储,然后在2011年才翻转回字符串-你可以使用JSON。解析来解释布尔值:
this.sidebar = !JSON.parse(this.sidebar);
我一直喜欢布尔值,但现在为了方便和调试,我使用二进制。你可以使用de consept !key: ++key:——key来切换,如果你在任何异步函数中,或者任何时候发生错误或false true,值将泄漏0(0)/ 1(1),你可以触发一个警报,稍后进行调试。
这是一个老问题,但我认为ES6的更新会很好。
通常,我们需要一个可以处理所有事情而不破坏代码的切换。
我们可以将null或未定义值的初始值作为false。
const boolToggler = b => !假) 让foo Console.log ('foo:', foo) //未定义 foo = boolToggler(foo) Console.log ('foo:', foo) // true(假设未定义为'false') foo = boolToggler(foo) console.log (foo:, foo);/ /错误 Let fee = null Console.log ('fee:', fee) // null fee = boolToggler(fee) Console.log ('fee:', fee) // true(假设null为'false') Let faa = true Console.log ('faa:', faa) // true faa = boolToggler(faa) console.log (faa:, faa);/ /错误