Javascript最佳化技巧之短路運算式詳細介紹

來源:互聯網
上載者:User

Javascript最佳化技巧之短路運算式詳細介紹

 這篇文章主要介紹了Javascript最佳化技巧之短路運算式詳細介紹,本文講解了什麼是短路運算式,並給出了一些樣本,需要的朋友可以參考下

 

 

什麼是短路運算式?

短路運算式:作為"&&"和"||"操作符的運算元運算式,這些運算式在進行求值時,只要最終的結果已經可以確定是真或假,求值過程便告終止,這稱之為短路求值。這是這兩個操作符的一個重要屬性。

一個最簡單的例子:

 

代碼如下:


foo = foo||bar;

 

這行代碼是什麼意思?答案:

 

代碼如下:


//如果foo存在,值不變,否則把bar的值賦給foo
if(!foo)
foo = bar;

 

在javascript的邏輯運算中,0、""、null、false、undefined、NaN都會判定為false,而其他都為true。所以在上式的foo = foo||bar;中,||先計算第一個運算數,如果可以被轉換成true,也就是表示foo已經存在有值,那麼返回左邊這個運算式的值,否則計算第二個運算數bar。

另外,即使||運算子的運算數不是布爾值,仍然可以將它看作布爾OR運算,因為無論它返回的值是什麼類型,都可以被轉換為布爾值。

當然,使用如下做法會更加嚴謹:

 

代碼如下:


if(foo) //不夠嚴謹

if(!!foo) //更為嚴謹,!!可將其他類型的值轉換為boolean類型

 

可以測試一下:

代碼如下:


var foo;
var number = 1;
var string = "string";
var obj = {};
var arr = [];


console.log(typeof(foo)); // undefined
console.log(typeof(number));  //number
console.log(typeof(string));  //string
console.log(typeof(obj));  //object  
console.log(typeof(arr));  //object

console.log(typeof(!!foo)); // boolean
console.log(typeof(!!number));  //boolean
console.log(typeof(!!string));  //boolean
console.log(typeof(!!obj));  //boolean
console.log(typeof(!!arr));  //boolean

 

利用這一點可以很好的符合,最佳化javascript工程一文中提到的,使指令碼少運行或者不運行,以達到最佳化javascript的目的。但是需要注意的是,這樣寫幫我們精簡了代碼的同時,也帶來了代碼可讀性的降低的缺點。所以比較好的做好是添加是適當的注釋。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.