怎样使你的 JavaScript 代码简单易读(推荐)

作者:疯狂的技术宅 时间:2024-04-16 09:53:22 

让我们先从怎样删除数组中的重复项这个简单问题开始。

复杂 - 使用 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 代码简单易读详解整合网站的支持!

来源:https://segmentfault.com/a/1190000018797269

标签:JavaScript,代码简单易读
0
投稿

猜你喜欢

  • 在ASP中用FormatDateTime格式化日期

    2010-08-08 19:16:00
  • python实现对求解最长回文子串的动态规划算法

    2023-11-09 10:18:49
  • 对python中的pop函数和append函数详解

    2021-10-09 09:11:32
  • Python Mysql数据库操作 Perl操作Mysql数据库

    2024-01-20 11:07:43
  • Python接入MySQL实现增删改查的实战记录

    2023-08-23 04:52:50
  • Python反射和内置方法重写操作详解

    2023-07-06 12:00:02
  • OpenCV中Canny边缘检测的实现

    2022-10-17 10:10:19
  • 让sql2005运行在独立用户下出现 WMI 提供程序错误的解决方式

    2024-01-13 13:12:50
  • Oracle关于时间/日期的操作

    2009-02-26 10:37:00
  • 解决golang 关于全局变量的坑

    2024-02-17 05:46:02
  • asp中字符编码转换的10个函数[荐]

    2007-11-11 10:32:00
  • MSSQL分页存储过程完整示例(支持多表分页存储)

    2024-01-15 10:19:21
  • 动易CMS:九个常见的错误原因分析及解决方法(ZT)

    2008-07-01 12:40:00
  • 如何在nodejs中体验http/2详解

    2024-05-05 09:21:48
  • colab中修改python版本的全过程

    2022-10-31 07:18:38
  • SQL语句中LEFT JOIN的ON和WHERE有什么区别

    2024-01-21 04:33:00
  • Python使用微信SDK实现的微信支付功能示例

    2022-09-22 00:19:41
  • MySQL 事务概念与用法深入详解

    2024-01-14 02:56:06
  • Python实现多态、协议和鸭子类型的代码详解

    2021-03-16 19:02:35
  • 女装类视觉设计分享

    2009-10-30 18:36:00
  • asp之家 网络编程 m.aspxhome.com