js短路表示式

2022-04-06 10:32:31 字數 1494 閱讀 1639

今天碰見個題目,感覺短路表示式很好用。

題目:

定義乙個計算圓面積的函式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;

console.log(a); //返回的結果為 2

如果邏輯與運算子左邊的值布林轉換後為true,那麼返回右邊的值(不管右邊的值是真還是假)。

var a = false && 2;

console.log(a); //返回的結果為 false

如果邏輯與運算子左邊的值布林轉換後為false,那麼返回左邊的值,但是當邏輯與的左邊為 null/nan/undefined ,結果就會得到null/nan/undefined。

2、邏輯或 || 的運算方式

如果邏輯或運算子左邊的值布林轉換後為false,那麼返回右邊的值(不管右邊的值是真還是假)。

如果邏輯或運算子左邊的值布林轉換後為true,那麼返回左邊的值,如果兩個運算元都是是null(nan/undefined),返回null(nan/undefined)

var a = false || 2;

console.log(a); //返回的結果為2

var a = true || 2;

console.log(a); //返回的結果為 true

3.短路表示式實際應用補充(2018-8-14)

(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&&(b=1);

a等於true則執行b=1,a=false則不執行b=1.用if寫:if(a=true)

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...