當我們爲變量賦值時,最好使用||。運營商還是?運營商?最佳實踐「OR」和「Ternary」運算符
例子:
OR
var x = window.scrollX || window.pageXOffset;
三元
var x = "scrollX" in window ? window.scrollX : window.pageXOffset;
什麼是最好的方法是什麼?
當我們爲變量賦值時,最好使用||。運營商還是?運營商?最佳實踐「OR」和「Ternary」運算符
例子:
OR
var x = window.scrollX || window.pageXOffset;
三元
var x = "scrollX" in window ? window.scrollX : window.pageXOffset;
什麼是最好的方法是什麼?
這兩者不等價。
在第一個版本中,您檢查scrollX值是否爲'。也就是說,如果它的undefined,false,null,0等等。
在第二個版本中,您檢查窗口對象是否具有scrollX
屬性。
例如:
如果你使用的第一個和scrollX
價值0
,它將使用pageXOffset
屬性值,而在兩個不同的版本,它會使用scrollX
值。
試試這個控制檯:
var a = { x: 0, y: 1 };
var or = a.x || a.y;
var tern = 'x' in a ? a.x : a.y;
console.log('or: ' + or);
console.log('tern: ' + tern);
var x = window.scrollX || window.pageXOffset;
上述方法有一些副作用。在這種情況下,JS中存在短路結構。無論window.scrollX需要什麼,總是會被接受。除非它是未定義的,否則x的所有結果都是window.scrollX
如果'scrollX'爲0會發生什麼事,你使用的第一個版本? – Jite
三元,總是:更具可讀性,更少「錯誤」傾向,請參閱http://programmers.stackexchange.com/questions/82593/javascript-ternary-operator-vs – Luca