對js運算符“||”和“&&”的總結

来源:http://www.cnblogs.com/cjm123/archive/2017/11/17/7850784.html
-Advertisement-
Play Games

首先出個題: 如圖: 假設對成長速度顯示規定如下: 成長速度為5顯示1個箭頭; 成長速度為10顯示2個箭頭; 成長速度為12顯示3個箭頭; 成長速度為15顯示4個箭頭; 其他都顯示都顯示0各箭頭。 用代碼怎麼實現? 差一點的if,else: Js代碼 var add_level = 0; if(ad ...


首先出個題:

如圖:

假設對成長速度顯示規定如下:

成長速度為5顯示1個箭頭;

成長速度為10顯示2個箭頭;

成長速度為12顯示3個箭頭;

成長速度為15顯示4個箭頭;

其他都顯示都顯示0各箭頭。

用代碼怎麼實現?

 

差一點的if,else:

Js代碼  收藏代碼
var add_level = 0;  
  
if(add_step == 5){  
    add_level = 1;  
}  
else if(add_step == 10){  
    add_level = 2;  
}  
else if(add_step == 12){  
    add_level = 3;  
}  
else if(add_step == 15){  
    add_level = 4;  
}  
else {  
    add_level = 0;  
}  

 

     

稍好些的switch:

Js代碼  收藏代碼
var add_level = 0;  
  
switch(add_step){  
    case 5 : add_level = 1;  
        break;  
    case 10 : add_level = 2;  
        break;  
    case 12 : add_level = 3;  
        break;  
    case 15 : add_level = 4;  
        break;  
    default : add_level = 0;  
        break;  
}  

  

如果需求改成:

成長速度為>12顯示4個箭頭;

成長速度為>10顯示3個箭頭;

成長速度為>5顯示2個箭頭;

成長速度為>0顯示1個箭頭;

成長速度為<=0顯示0個箭頭。

 

那麼用switch實現起來也很麻煩了。

 

那麼你有沒有想過用一行就代碼實現呢?

ok,讓我們來看看js強大的表現力吧:

Js代碼  收藏代碼
var add_level = (add_step==5 && 1) || (add_step==10 && 2) || (add_step==12 && 3) || (add_step==15 && 4) || 0;   

 

更強大的,也更優的:

 

Js代碼  收藏代碼
var add_level={'5':1,'10':2,'12':3,'15':4}[add_step] || 0;  

  

第二個需求:

Js代碼  收藏代碼
var add_level = (add_step>12 && 4) || (add_step>10 && 3) || (add_step>5 && 2) || (add_step>0 && 1) || 0;

  

  


首先我們來梳理一下一個概念,請你一定要記住:在js邏輯運算中,0、""、null、false、undefined、NaN都會判為false,其他都為true(好像沒有遺漏了吧,請各位確認下)。這個一定要記住,不然應用||和&&就會出現問題。

這裡順便提下:經常有人問我,看到很多代碼if(!!attr),為什麼不直接寫if(attr);
其實這是一種更嚴謹的寫法:
請測試 typeof 5和typeof !!5的區別。!!的作用是把一個其他類型的變數轉成的bool類型。

下麵主要討論下邏輯運算符&&和||。

幾乎所有語言中||和&&都遵循“短路”原理,如&&中第一個表達式為假就不會去處理第二個表達式,而||正好相反。
js也遵循上述原則。但是比較有意思的是它們返回的值。
代碼:var attr = true && 4 && “aaa”;
那麼運行的結果attr就不是簡單的true或這false,而是”aaa”
再來看看||:
代碼:var attr = attr || “”;這個運算經常用來判斷一個變數是否已定義,如果沒有定義就給他一個初始值,這在給函數的參數定義一個預設值的時候比較有用。因為js不像php可以直接在型參數上定義func($attr=5)。再次提醒你記住上面的原則:如果實參需要是0、""、null、false、undefined、NaN的時候也會當false來處理。


if(a >=5){

    alert("你好");
}
可以寫成:
a >= 5 && alert("你好");


這樣只需一行代碼就搞定。但是需要註意的一點就是:js中||和&&的特性幫我們精簡了代碼的同時,也帶來了代碼可讀性的降低。這就需要我們自己來權衡了。
一方面精簡js代碼,能實質性的減少網路流量,尤其是大量應用的js公用庫。個人比較推薦的做法是:如果是相對複雜的應用,請適當地寫一些註釋。這個和正在表達式一樣,能夠精簡代碼,但是可讀性會降低,對讀代碼的人要求會高些,最好的辦法就是寫註釋。

 

我們可以不使用這些技巧,但是我們一定要能看懂,因為這些技巧已經廣泛應用,尤其是像JQuery等js框里的代碼,不理解這些你就很難看懂別人的代碼。

像var Yahoo = Yahoo || {};這種是非常廣泛應用的。

 

ok,最後讓我們來看一段jQuery中的代碼吧:

 

Js代碼  收藏代碼
var wrap =  
    // option or optgroup  
    !tags.indexOf("<opt") &&  
    [ 1, "<select multiple='multiple'>", "</select>" ] ||  
      
    !tags.indexOf("<leg") &&  
    [ 1, "<fieldset>", "</fieldset>" ] ||  
      
    tags.match(/^<(thead|tbody|tfoot|colg|cap)/) &&  
    [ 1, "<table>", "</table>" ] ||  
      
    !tags.indexOf("<tr") &&  
    [ 2, "<table><tbody>", "</tbody></table>" ] ||  
      
    // <thead> matched above  
    (!tags.indexOf("<td") || !tags.indexOf("<th")) &&  
    [ 3, "<table><tbody><tr>", "</tr></tbody></table>" ] ||  
      
    !tags.indexOf("<col") &&  
    [ 2, "<table><tbody></tbody><colgroup>", "</colgroup></table>" ] ||  
      
    // IE can't serialize <link> and <script> tags normally  
    !jQuery.support.htmlSerialize &&  
    [ 1, "div<div>", "</div>" ] ||  
      
    [ 0, "", "" ];  
      
    // Go to html and back, then peel off extra wrappers  
    div.innerHTML = wrap[1] + elem + wrap[2];  
      
    // Move to the right depth  
    while ( wrap[0]-- )  
        div = div.lastChild;  

  

 

這段代碼是作者用來處理 $(html) 時,有些標簽必須要約束的,如<option>必須在<select></select>之內的。

可能你也發現了作者還有一個很巧的地方就是 !tags.indexOf("<opt") ,作者很巧很簡單的就實現了startWith的功能了,沒有一點多餘的代碼。jquery源代碼中還有很多如此精妙的代碼,大家可以去學習學習。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在使用由Angular,React,Vue等應用程式框架構建的客戶端應用程式時,您總是會處理HTML5客戶端路由,它將完全在瀏覽器中處理到頁面和組件的客戶端路由。幾乎完全在瀏覽器中... HTML5客戶端路由在客戶端上工作的很好,但是當深入鏈接到一個站點或在瀏覽器中按刷新時,客戶端路由有一個惡習,變 ...
  • DEV控制項GridControl和TreeList的數據導出操作 ...
  • 學習:C#綜合揭秘——Entity Framework 併發處理詳解 帖子筆記 ,該帖子使用的是objectContext , 一、併發相關概念 併發的類型: 第一種模式稱為悲觀式併發,即當一個用戶已經在修改某條記錄時,系統將拒絕其他用戶同時修改此記錄。第二種模式稱為樂觀式併發,即系統允許多個用戶同... ...
  • Visual Studio 2017是微軟為了配合.NET戰略推出的IDE開發環境,同時也是目前開發C#程式最新的工具,本節以Visual Studio 2017社區版的安裝為例講解具體的安裝步驟。 說明:Visual Studio 2017 社區版是完全免費的,其下載地址為:https://www ...
  • 一、簡介 Topshelf可用於創建和管理Windows服務。其優勢在於不需要創建windows服務,創建控制台程式就可以。便於調試。 二、官方地址: 1、官網:http://topshelf-project.com/ 2、官方文檔:https://topshelf.readthedocs.io/e ...
  • 關於WCF即可以寄宿於IIS,也可以自我寄宿,本文采用的是自我寄宿方式。之所以採用自我寄宿方式,很大程度上,在一些特殊的場景,例如下載大文件(如幾百MB、1G等)、圖片、文檔等,如果以IIS為宿主,可能會產生記憶體不夠用。所以這裡採用自我寄宿的方式為例子。WCF是由微軟開發的一系列支持數據通信的應用程... ...
  • 問題描述 在發佈項目的時候,有一些文件是json文件,在網頁中進行載入,但是在IIS7發佈的時候,json文件居然是404,無法找到,在URL上輸入地址也一樣。 錯誤原因 IIS內部機制,不支持直接訪問json擴展名文件,沒有mime映射。因此IIS不認Json文件,如需要支持訪問json文件時,需 ...
  • 上一篇文章介紹了使用Authorize特性實現了ASP.NET MVC中針對Controller或者Action的授權功能,實際上這個特性是MVC功能的一部分,被稱為過濾器(Filter),它是一種面向切麵編程(AOP)的實現,本章將從以下幾個方面來介紹ASP.NET MVC中的過濾器。 ● ASP ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...