欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

怎樣使你的 JavaScript 代碼簡單易讀(推薦)

 更新時間:2019年04月16日 15:42:11   作者:瘋狂的技術(shù)宅  
這篇文章主要介紹了怎樣使你的 JavaScript 代碼簡單易讀,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

讓我們先從怎樣刪除數(shù)組中的重復(fù)項這個簡單問題開始。

復(fù)雜 - 使用 forEach 刪除重復(fù)項

首先,我們新創(chuàng)建一個空數(shù)組,用 forEach() 在數(shù)組的每個元素上執(zhí)行一次提供的函數(shù)。最后檢查新數(shù)組中是否存在該值,如果不存在,則添加它。

function removeDuplicates(arr) { 
  const uniqueVals = [];  
  arr.forEach((value,index) => {   
    if(uniqueVals.indexOf(value) === -1) {
      uniqueVals.push(value);
    } 
  });
 return uniqueVals;
}

簡單 - 使用 filter 刪除重復(fù)項

filter 方法創(chuàng)建一個包含所有元素的新數(shù)組,通過提供的函數(shù)進(jìn)行測試。基本上我們只需要迭代數(shù)組,并檢查當(dāng)前元素在數(shù)組中出現(xiàn)的第一個位置是否和當(dāng)前位置相同。當(dāng)然,這兩個位置對于重復(fù)元素來說是不同的。

function removeDuplicates(arr) {
 return arr.filter((item, pos) => arr.indexOf(item) === pos)
}

簡單 - 使用 Set 刪除重復(fù)項

ES6 提供了 Set 對象,這使事情變得更加容易。 Set 僅允許存在唯一值,所以當(dāng)你傳入數(shù)組時,它會自動刪除重復(fù)的值。
但是,如果你需要一個包含唯一元素的數(shù)組,為什么不一開始就用 Set 呢?

 

function removeDuplicates(arr) {
  return [...new Set(arr)];
}

 接下來讓我們解決第二個問題:寫一個函數(shù),向該函數(shù)傳入一組非負(fù)整數(shù),其中的值各不不同,要求使它們連續(xù),并返回缺失的數(shù)字個數(shù)。

對于const arr = [4,2,6,8],輸出應(yīng)為

countMissingNumbers(arr)= 3

你可以看到 3,5 和 7 是缺失的。

復(fù)雜 - 使用 sort 和 for 循環(huán)解決

要獲得最小和最大的數(shù)字,我們需要用用 sort方法按升序進(jìn)行排序來達(dá)到這個目的,然后從最小的數(shù)字循環(huán)到最大的數(shù)字。每次檢查數(shù)組中是否存在應(yīng)該出現(xiàn)的序號,如果不存在,就對計數(shù)器加一。

function countMissingNumbers(arr) {
  arr.sort((a,b) => a-b);  
  let count = 0;  
  const min = arr[0];  
  const max = arr[arr.length-1];
  for (i = min; i<max; i++) {
   if (arr.indexOf(i) === -1) {
     count++;     
   }   
  }    
  return count;
}

簡單 - 使用 Math.max 和 Math.min 求解

這個解決方案有一個簡單的解釋:Math.max()函數(shù)返回數(shù)組中最大的數(shù)字,而Math.min() 返回數(shù)組中最小的數(shù)字。

首先,如果沒有丟失數(shù)字,我們能知道數(shù)組中有多少個數(shù)字。所以可以用以下公式 maxNumber - minNuber + 1,并用這個結(jié)果減去數(shù)組長度,得到的差就是缺失數(shù)字的個數(shù)。

function countMissingNumbers(arr) {
   return Math.max(...arr) - Math.min(...arr) + 1 - arr.length;
}

最后一個問題是檢查字符串是否為回文。所謂 回文 是一個從左到右和從右到左讀起來都一樣的字符串。

復(fù)雜 - 使用 for 循環(huán)檢查

這個方法的循環(huán)從字符串的第一個字符開始,一直到字符串長度的一半。字符串中最后一個字符的索引是 string.length-1,倒數(shù)第二個字符的索引是string.length-2,依此類推。所以在這里我們檢查從左邊開始的指定索引處的字符是否等于右邊指定索引處的字符。如果它們不相等,就返回false。

function checkPalindrome(inputString) { 
  let length = inputString.length
  for (let i =0; i<length / 2; i++) {
    if (inputString[i] !== inputString[length - 1 -i]) {
       return false    
    }
  }
 return true
}

簡單 - 用 reverse 和 join 檢查

我認(rèn)為這個解決方案簡單到不需要解釋,因為代碼本身說明了一切。我們只需使用 spread operator 從字符串創(chuàng)建一個數(shù)組,然后reverse數(shù)組,最后用 join 方法將其再次轉(zhuǎn)換為字符串,并與原始字符串進(jìn)行比較。

function checkPalindrome(string) {
  return string === [...string].reverse().join('');
}

保持簡單!

當(dāng)有更簡單的方法時,為什么要搞得那么復(fù)雜?希望你能從這篇文章中學(xué)到一些很有意思的思路。祝你有一個美好的編碼時間,盡量不要讓生活中簡單的事情復(fù)雜化。

以上所述是小編給大家介紹的怎樣使你的 JavaScript 代碼簡單易讀詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • JavaScript可視化與Echarts詳細(xì)介紹

    JavaScript可視化與Echarts詳細(xì)介紹

    提到數(shù)據(jù)可視化相信大家都不陌生,它能夠?qū)我坏臄?shù)據(jù)通過合適的可視化圖表類型表現(xiàn)出來,使其更加直觀的展現(xiàn)數(shù)據(jù)的變化趨勢、對比、峰值等等。其實在前端開發(fā)中,數(shù)據(jù)可視化也尤為重要,在眾多圖表庫中,echarts就是最常見的圖表庫之一
    2022-07-07
  • 激活 ActiveX 控件

    激活 ActiveX 控件

    激活 ActiveX 控件...
    2006-10-10
  • javascript結(jié)合Flexbox簡單實現(xiàn)滑動拼圖游戲

    javascript結(jié)合Flexbox簡單實現(xiàn)滑動拼圖游戲

    本文給大家分享的是一則使用javascript結(jié)合Flexbox簡單實現(xiàn)滑動拼圖游戲的代碼,雖然沒有實現(xiàn)完整的功能,但是還是推薦給大家,喜歡的朋友可以繼續(xù)做完
    2016-02-02
  • Bootstrap輸入框組件簡單實現(xiàn)代碼

    Bootstrap輸入框組件簡單實現(xiàn)代碼

    這篇文章主要為大家詳細(xì)介紹了Bootstrap輸入框組件的簡單實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • Google Maps API地圖應(yīng)用示例分享

    Google Maps API地圖應(yīng)用示例分享

    這篇文章主要分享一段了Google Maps API地圖應(yīng)用示例,做項目中經(jīng)常會使用到,非常的簡單,有需要的朋友可以參考下
    2014-10-10
  • js實現(xiàn)隨機數(shù)小游戲

    js實現(xiàn)隨機數(shù)小游戲

    這篇文章主要為大家詳細(xì)介紹了js實現(xiàn)隨機數(shù)小游戲,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • uniapp實現(xiàn)審批流程的具體操作步驟

    uniapp實現(xiàn)審批流程的具體操作步驟

    這篇文章主要介紹了uniapp實現(xiàn)審批流程的具體操作方法,實現(xiàn)思路大概是需要要定義一個變量,記錄當(dāng)前激活的步驟,通過數(shù)組的長度來循環(huán)數(shù)據(jù),如果有就采用3元一次進(jìn)行選擇,具體實現(xiàn)步驟跟隨小編一起看看吧
    2024-03-03
  • javascript代碼簡寫的幾種常用方式匯總

    javascript代碼簡寫的幾種常用方式匯總

    任何一種編程語言的簡寫小技巧都是為了幫助你寫出更簡潔、更完善的代碼,讓你用更少的編碼實現(xiàn)你的需求,這篇文章主要給大家介紹了關(guān)于javascript代碼簡寫的幾種常用方式,需要的朋友可以參考下
    2021-08-08
  • 使用VSCode調(diào)試Electron主進(jìn)程的方法步驟

    使用VSCode調(diào)試Electron主進(jìn)程的方法步驟

    本文主要介紹了使用VSCode調(diào)試Electron主進(jìn)程的方法步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • javascript 按回車鍵相應(yīng)按鈕提交事件

    javascript 按回車鍵相應(yīng)按鈕提交事件

    在表單提交前經(jīng)常遇到表單驗證問題而常用的方法有以下兩種.
    2009-11-11

最新評論