亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-10-19 10:40:24 來源:腳本之家 閱讀:146 作者:瘋狂的技術宅 欄目:web開發

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

復雜 - 使用 forEach 刪除重復項

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

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

簡單 - 使用 filter 刪除重復項

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

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

簡單 - 使用 Set 刪除重復項

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

 

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

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

對于const arr = [4,2,6,8],輸出應為

countMissingNumbers(arr)= 3

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

復雜 - 使用 sort 和 for 循環解決

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

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()函數返回數組中最大的數字,而Math.min() 返回數組中最小的數字。

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

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

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

復雜 - 使用 for 循環檢查

這個方法的循環從字符串的第一個字符開始,一直到字符串長度的一半。字符串中最后一個字符的索引是 string.length-1,倒數第二個字符的索引是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 檢查

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

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

保持簡單!

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

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

朔州市| 潜山县| 武宣县| 静海县| 前郭尔| 开江县| 富蕴县| 湘潭市| 望奎县| 丹凤县| 台山市| 汽车| 武城县| 阳高县| 红安县| 河曲县| 定安县| 耿马| 光泽县| 柳江县| 来凤县| 犍为县| 云安县| 绥德县| 清水县| 都江堰市| 芒康县| 鹿泉市| 宾川县| 登封市| 南阳市| 衡阳县| 朔州市| 隆子县| 民县| 吉木萨尔县| 迁西县| 五莲县| 成安县| 松江区| 永济市|