今天碰見個題目,感覺短路表示式很好用。
題目:
定義乙個計算圓面積的函式area_of_circle(),它有兩個引數:我的寫法:r: 表示圓的半徑;
pi: 表示π的值,如果不傳,則預設3.14
function area_of_circle(r, pi)
if(arguments.length>=2)別人寫法:else if(arguments.length==1)
else return false;
return r*r*( arguments.length >= 2 ? pi : 3.14 );大神寫法:
return r * r * (pi || 3.14);短路表示式知識補充:
1、邏輯與 && 的運算方式
var a = 1 && 2;如果邏輯與運算子左邊的值布林轉換後為true,那麼返回右邊的值(不管右邊的值是真還是假)。console.log(a); //返回的結果為 2
var a = false && 2;如果邏輯與運算子左邊的值布林轉換後為false,那麼返回左邊的值,但是當邏輯與的左邊為 null/nan/undefined ,結果就會得到null/nan/undefined。console.log(a); //返回的結果為 false
2、邏輯或 || 的運算方式
如果邏輯或運算子左邊的值布林轉換後為false,那麼返回右邊的值(不管右邊的值是真還是假)。
如果邏輯或運算子左邊的值布林轉換後為true,那麼返回左邊的值,如果兩個運算元都是是null(nan/undefined),返回null(nan/undefined)
var a = false || 2;3.短路表示式實際應用補充(2018-8-14)console.log(a); //返回的結果為2
var a = true || 2;
console.log(a); //返回的結果為 true
(1)正規表示式
v => !v || /^([0-9])|(0?(13|14|15|17|18|19)[0-9])$/.test(v) || '格式錯誤',前邊為true則不再執行後邊的,前邊為false則繼續往後執行。
(2)if的簡化
vm.queryselobj[key] && (params[key] = vm.queryselobj[key]);a等於true則執行b=1,a=false則不執行b=1.用if寫:if(a=true)相當於 a&&(b=1);
JS短路表示式
var a 1,b 1,c 2 a b c 2 a 0 c false a b c true a 0 c 2 x y 首先在運算子比之前會自動把x轉換為boolean值,不管它是什麼型別。若x為false,不管y為什麼,都將返回false 若x為true,則返回y,若y可以是基本型別,也可以是引用型...
js短路表示式
返回第乙個假值,或者最後乙個真值 如果邏輯與運算子左邊的值布林轉換後為true,那麼返回右邊的值 不管右邊的值是真還是假 let a 5 6 console.log a 6如果邏輯與運算子左邊的值布林轉換後為false,那麼返回左邊的值,但是當邏輯與的左邊為 null nan undefined 結...
VUE 短路表示式
在正常情況下,全真才真 一假則假。全假則假,一真則真。但是今天要說的是短路表示式。this.autologin this.rememb true 如果this.autologin 是真,則執行 this.rememb true 如果this.autologin是假,則返回執行this.autolog...