|| 與 &&在js裡與其它語言不一樣,這是選擇器運算子,而非邏輯運算子。
對於||來說,若判斷為true,則返回第乙個值,為false返回第二個值。
&&相反,若判斷為 true,則返回第二個,為 false為返回第乙個值。
絕對不是像其它語言那樣返回true或false,而是會返回第乙個值或第二個值。
簡單的測試**如下,先是true與false的測試,後將false改為數值0. 除了|| 與&&之外易讓人疑惑外,js裡的假值表也算是個大疑點。
let a = true;
let b = true;
testlogic(a,b);
a = true;
b = false;
testlogic(a,b);
a = false;
b = true;
testlogic(a,b);
a = false;
b = false;
testlogic(a,b);
/*假值表,以下值 可以被強制布林轉換為false,其它轉換皆為true
undefined
null
false
+0,-0,nan
"" 空字串
其它皆為真值,如空物件{}
我寫**時我其實就只知道如何做到if 與邏輯判斷實現其它語言一樣的正常的效果:
結論是保證a與b的是true或false而不是其它值。
正常語言是這樣的:ab
a||b
a&&btt
tttf
tfft
tfff
ffjs語言是這樣的:返回的是a或b,只要保證a與b的是true或false而不是其它值,那麼在使用上與正常語言邏輯一樣。a
ba||b
a&&btt
a(t)
b(t)tf
a(t)
b(f)ft
b(t)
a(f)ff
b(f)
a(f)
js 選擇器相容
1.document.getelementbyid 所有主要瀏覽器都支援 getelementbyid 方法 2.document.getelementsbytagname 和element.getelementsbytagname 所有主要瀏覽器都支援 getelementsbytagname 方...
JS獲取選擇器
原生js選擇器有getelementbyid getelementsbyname getelementsbytagname和getelementsbyclassname這四個,下面我就乙個乙個介紹這四個選擇器的用法。1.getelementbyid 通過id獲取元素 用法 document.gete...
Js選擇器總結
js選擇器常用的有getelementbyid getelementsbyname getelementsbytagname getelementsbyclassname queryselector queryselectorall 內容基本選擇器有id選擇器 類選擇器 標籤選擇器 通用選擇器,事件...