对于初学者,JavaScript 有哪些不为人知却非常有用的技巧呢?在本文中,我们将一同为大家解密与分享。

作者 | Duomly
译者 | 弯月,责编 | 屠敏
出品 | CSDN(ID:CSDNnews)

以下为译文:

数组是Javascript中最常见的概念,我们有很多办法来处理数组中的数据。考虑到数组是Javascript中最基本的概念之一,是初学者刚刚接触编程时就学习的概念,我想通过本文介绍一些不为人知却非常有用的技巧。我们开始吧!

从数组中删除重复

在有关Javascript数组的面试问题中,有一个问题很常见:怎样从Javascript数组中提取不重复的值。我有一个快捷简便的方法:只需使用new Set()即可。实现的方法有两种:一种使用.from(),另一种使用扩展运算符(...):

var fruits = [“banana”, “apple”, “orange”, “watermelon”, “apple”, “orange”, “grape”, “apple”];

很容易,是不是?

替换数组中指定的值

在编程时,有时候需要替换某个特定的值,有个非常简单的方法来实现这一点。只需使用.split(start, 要删除的值,要添加的值),然后设置好三个参数,指明希望从哪里修改、要修改几个值,以及新的值是什么。

var fruits = [“banana”, “apple”, “orange”, “watermelon”, “apple”, “orange”, “grape”, “apple”];
fruits.splice(0, 2, “potato”, “tomato”);
console.log(fruits); // returns [“potato”, “tomato”, “orange”, “watermelon”, “apple”, “orange”, “grape”, “apple”]

不使用.map()实现映射

大概所有人都知道数组的.map()方法,但还有另一个方法,可以用同样简洁的方式实现类似的效果。这种方法就是.from():

var friends = [{ name: ‘John’, age: 22 },{ name: ‘Peter’, age: 23 },{ name: ‘Mark’, age: 24 },{ name: ‘Maria’, age: 22 },{ name: ‘Monica’, age: 21 },{ name: ‘Martha’, age: 19 },
]var friendsNames = Array.from(friends, ({name}) => name);
console.log(friendsNames); // returns [“John”, “Peter”, “Mark”, “Maria”, “Monica”, “Martha”]

清空数组 

如果想把一个数组清空,但不想一个个删除其中的元素,该怎么办?其实只需一行代码即可:将length设置为0。

var fruits = [“banana”, “apple”, “orange”, “watermelon”, “apple”, “orange”, “grape”, “apple”];fruits.length = 0;
console.log(fruits); // returns []

将数组转化为对象

如果有一个数组,我们希望将其数据放到一个对象中,那么最快的方式就是使用扩展运算符(...):

var fruits = [“banana”, “apple”, “orange”, “watermelon”];
var fruitsObj = { …fruits };
console.log(fruitsObj); // returns {0: “banana”, 1: “apple”, 2: “orange”, 3: “watermelon”, 4: “apple”, 5: “orange”, 6: “grape”, 7: “apple”}

用数据填充数组

有时候需要创建一个数组并用数据填充,或者需要一个所有值都相同的数组,此时可以使用.fill()方法简洁明快地实现:

var newArray = new Array(10).fill(“1”);
console.log(newArray); // returns [“1”, “1”, “1”, “1”, “1”, “1”, “1”, “1”, “1”, “1”, “1”]

合并数组

你知道怎样可以不使用.concat()来合并数组吗?最简单的方法只需要一行代码。你也许猜到了,那就是扩展运算符(...),它非常适合处理数组:

var fruits = [“apple”, “banana”, “orange”];
var meat = [“poultry”, “beef”, “fish”];
var vegetables = [“potato”, “tomato”, “cucumber”];
var food = […fruits, …meat, …vegetables];
console.log(food); // [“apple”, “banana”, “orange”, “poultry”, “beef”, “fish”, “potato”, “tomato”, “cucumber”]

求两个数组的交集

这也是Javascript面试中最常遇到的问题,因为它能展示出你是否会使用数组方法,以及逻辑如何。要找出两个数组的交集,只需要使用之前使用的技巧,首先保证数组中的值不重复,然后利用.filter和.includes方法即可。这样就能找出同时出现在两个数组中的元素。代码如下:

var numOne = [0, 2, 4, 6, 8, 8];
var numTwo = [1, 2, 3, 4, 5, 6];
var duplicatedValues = […new Set(numOne)].filter(item => numTwo.includes(item));
console.log(duplicatedValues); // returns [2, 4, 6]

从数组中删除假值

首先我们来定义假值。在Javascript中,假值包括false、0、''、null、NaN、undefined。现在可以考虑怎样从数组中删除假值了。只需使用.filter()方法即可实现:

var mixedArr = [0, “blue”, “”, NaN, 9, true, undefined, “white”, false];
var trueArr = mixedArr.filter(Boolean);
console.log(trueArr); // returns [“blue”, 9, true, “white”]

从数组中获取随机值

有时候需要从数组中随机选择一个值。简单、快捷、简短且干净的方式就是在数组长度的范围内生成一个随机的索引。代码如下:

var colors = [“blue”, “white”, “green”, “navy”, “pink”, “purple”, “orange”, “yellow”, “black”, “brown”];
var randomColor = colors[(Math.floor(Math.random() * (colors.length)))]

反转数组

需要反转数组时,我们不需要使用复杂的循环和函数来重新创建数组,因为有一个简单的数组方法可以为我们做这件事,只需一行代码,就能反转数组。代码如下:

var colors = [“blue”, “white”, “green”, “navy”, “pink”, “purple”, “orange”, “yellow”, “black”, “brown”];
var reversedColors = colors.reverse();
console.log(reversedColors); // returns [“brown”, “black”, “yellow”, “orange”, “purple”, “pink”, “navy”, “green”, “white”, “blue”]

.lastIndexOf()方法

Javascript中有一个有趣的方法,可以让我们找出指定元素最后出现的位置。例如,如果数组中有重复元素,那么可以找出该元素最后出现的位置。代码如下:

var nums = [1, 5, 2, 6, 3, 5, 2, 3, 6, 5, 2, 7];
var lastIndex = nums.lastIndexOf(5);
console.log(lastIndex); // returns 9

对数组中的所有值求和

另一个Javascript工程师面试中常见的问题就是对数组中的所有元素求和。这个完全不需要害怕,只需使用.reduce方法,一行代码就可以实现。代码如下:

var nums = [1, 5, 2, 6];
var sum = nums.reduce((x, y) => x + y);
console.log(sum); // returns 14

总结

本文向你展示了13个编程技巧,可以保持代码简短整洁。同时别忘了,Javascript中还有许多不同的技巧值得探索,不仅是有关数组的技巧,也包括许多其他的数据类型。希望你喜欢本文的技巧,并能利用这些技巧改善开发流程。

原文:https://dev.to/duomly/13-useful-javascript-array-tips-and-tricks-you-should-know-2jfo

本文为 CSDN 翻译,转载请注明来源出处。

【END】

每个 Python 学习者都值得一试,快看!

https://edu.csdn.net/topic/python115?utm_source=csdn_bw

 热 文 推 荐 

一文了解超级账本DLT、库、开发工具有哪些, Hyperledger家族成员你认识几个?
点击阅读原文参与问卷,好礼送不停!
你点的每个“在看”,我都认真当成了喜欢

​不容错过的 13 个 JavaScript 实用技巧!相关推荐

  1. 不容错过的 15 个 Linux 实用技巧

    [CSDN 编者按]使用Linux最酷的事情之一就是随着时间的推移,你可以不断获得新的知识.每天,你都可能会遇到一个新的实用工具,即使是这样,也不可能事事皆知.无论你有多少经验,可能总会有更多东西去学 ...

  2. 13 种 JavaScript 代码技巧

    13 种 JavaScript 代码技巧 1. 多表达式多 if 判断 我们可以在数组中存储多个值,并且可以使用数组include方法. // 长 if (x === 'abc' || x === ' ...

  3. JavaScript实用技巧(一)

    JavaScript 的成功让人津津乐道,为 Web 网页编写 JavaScript 代码已经是所有 Web 设计师的基本功,这门有趣的语言蕴藏着许多不为人熟知的东西,即使多年的 JavaScript ...

  4. 13个Pandas实用技巧,有点香 !

    作者:风控猎人 归纳整理了一些工作中常用到的pandas使用技巧,方便更高效地实现数据分析.文章很短,不用收藏就能Get~ 1.计算变量缺失率 df=pd.read_csv('titanic_trai ...

  5. Web前端开发培训之41个JavaScript实用技巧

    1. 将彻底屏蔽鼠标右键 <font size= "3" >οncοntextmenu="window.event.returnValue= false &q ...

  6. javascript实用技巧--数组.

    数组和字符串类型对象的方法我特容易搞混淆,所以把他列出来,免得每次取查. 1.concat方法 [作用] 将多个数组联合起来,这个方法不会改变现存的数组,它只返回了所结合数组的一份拷贝. [语法] a ...

  7. 38个Pandas实用技巧

    1.计算变量缺失率 df=pd.read_csv('titanic_train.csv') def missing_cal(df):"""df :数据集return:每个 ...

  8. @程序员,不容错过的 Vim 实用技巧请查收!

    Vim 是 Linux 系统上的最著名的文本/代码编辑器,也是早年的 Vi 编辑器的加强版.一直以来,Vim 普遍被推崇为类 Vi 编辑器中最好的一个,其拥有代码补全.编译及错误跳转等诸多丰富的功能, ...

  9. 立足GitHub学编程:13个不容错过的Java项目

    今天我们将整理一大波干货满满的优秀Java项目. GitHub可谓一座程序开发的大宝库,有些项目值得fork,有些则能帮助我们改进自有代码或者学习编程技能.无论如何,开发工作当中我们几乎不可能绕得开G ...

最新文章

  1. boost log 能不能循环覆盖_前端基础进阶(十四):深入核心,详解事件循环机制...
  2. 工作中使用计算机的经验,事业单位考试中计算机工作经历是什么意思
  3. 去掉星空极速,开通ADSL路由
  4. C# 8的Ranges和递归模式
  5. 关于target=标签
  6. 巧用Windows Phone应用商城中的应用链接
  7. wordpress插件在服务器上的存储位置
  8. where used list repository table WBCROSSGT
  9. Zune 3.0与XNA GS 3.0 Beta
  10. 毕业三年,攒了多少钱?
  11. Unity MRTK(一)
  12. Cache基本原理之:结构
  13. Atitit 遍历文件夹目录解决方案与规范 attilax总结 1. 规范 2 1.1. 注意的不要同时改变文件夹内容,增删文件。这样获取到的目录list不会变化 2 1.2. 主义中文名称文件读写
  14. VB 连接加密码的ACCESS数据库*.mdb,*.accdb
  15. SiT9386:AEC-Q100认证汽车级差分振荡器1-220MHz任意频率
  16. 计算机怎么没有word文档,电脑新建没有word文档怎么办 没有Word解决方法
  17. 宁海元 mysql_每公斤约360元 宁海香榧可以品尝了
  18. Android Text文字详解
  19. SSM框架和SpringBoot框架的对比
  20. vite的public目录

热门文章

  1. [Linux 性能检测工具]IOSTAT
  2. add in Web.config
  3. ASCII控制字符在vi和notepadd++中的表示法
  4. AttributeError: module ‘tensorflow.python.layers.base‘ has no attribute ‘Node‘
  5. python list 的深浅拷贝探索
  6. leetcode python3 简单题108. Convert Sorted Array to Binary Search Tree
  7. leetcode python3 简单题100. Same Tree
  8. 【图像处理】MATLAB:表示与描述
  9. Flutter从入门到进阶
  10. C语言TCP客户端获取时间