iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > html >怎么用JS数组技巧提高开发技能
  • 492
分享到

怎么用JS数组技巧提高开发技能

2024-04-02 19:04:59 492人浏览 安东尼
摘要

本篇内容介绍了“怎么用js数组技巧提高开发技能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 随机排列

本篇内容介绍了“怎么用js数组技巧提高开发技能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

1. 随机排列

在开发者,有时候我们需要对数组的顺序进行重新的洗牌。在 JS 中并没有提供数组随机排序的方法,这里提供一个随机排序的方法:

function shuffle(arr) {   var i, j, temp;   for (i = arr.length - 1; i > 0; i--) {     j = Math.floor(Math.random() * (i + 1));     temp = arr[i];     arr[i] = arr[j];     arr[j] = temp;   }   return arr; }

2. 唯一值

在开发者,我们经常需要过滤重复的值,这里提供几种方式来过滤数组的重复值。

使用 Set 对象

使用 Set() 函数,此函数可与单个值数组一起使用。对于数组中嵌套的对象值而言,不是一个好的选择。

const numArray = [1,2,3,4,2,3,4,5,1,1,2,3,3,4,5,6,7,8,2,4,6];  // 使用 Array.from 方法 Array.from(new Set(numArray));  // 使用展开方式 [...new Set(numArray)]

使用 Array.filter

使用 filter 方法,我们可以对元素是对象的进行过滤。

const data = [   {id: 1, name: 'Lemon'},   {id: 2, name: 'Mint'},   {id: 3, name: 'ManGo'},   {id: 4, name: 'Apple'},   {id: 5, name: 'Lemon'},   {id: 6, name: 'Mint'},   {id: 7, name: 'Mango'},   {id: 8, name: 'Apple'}, ]  function findUnique(data) {   return data.filter((value, index, array) => {     if (array.findIndex(item => item.name === value.name) === index) {       return value;     }   }) }

3. 使用 loadsh 的 lodash 方法

import {uniqBy} from 'lodash'  const data = [    {id: 1, name: 'Lemon'},    {id: 2, name: 'Mint'},    {id: 3, name: 'Mango'},    {id: 4, name: 'Apple'},    {id: 5, name: 'Lemon'},    {id: 6, name: 'Mint'},   {id: 7, name: 'Mango'},    {id: 8, name: 'Apple'},  ]   function findUnique(data) {    return uniqBy(data, e => {      return e.name     }) }

3. 按属性对 对象数组 进行排序

我们知道 JS 数组中的 sort 方法是按字典顺序进行排序的,所以对于字符串类,  该方法是可以很好的正常工作,但对于数据元素是对象类型,就不太好使了,这里我们需要自定义一个排序方法。

在比较函数中,我们将根据以下条件返回值:

小于0:A 在 B 之前

大于0 :B 在 A 之前

等于0 :A 和 B 彼此保持不变

const data = [   {id: 1, name: 'Lemon', type: 'fruit'},   {id: 2, name: 'Mint', type: 'vegetable'},   {id: 3, name: 'Mango', type: 'grain'},   {id: 4, name: 'Apple', type: 'fruit'},   {id: 5, name: 'Lemon', type: 'vegetable'},   {id: 6, name: 'Mint', type: 'fruit'},   {id: 7, name: 'Mango', type: 'fruit'},   {id: 8, name: 'Apple', type: 'grain'}, ]  function compare(a, b) {   // Use toLowerCase() to ignore character casing   const typeA = a.type.toLowerCase();   const typeB = b.type.toLowerCase();    let comparison = 0;   if (typeA > typeB) {     comparison = 1;   } else if (typeA < typeB) {     comparison = -1;   }   return comparison; }  data.sort(compare)

4. 把数组转成以指定符号分隔的字符串

JS 中有个方法可以做到这一点,就是使用数组中的 .join() 方法,我们可以传入指定的符号来做数组进行分隔。

const data = ['Mango', 'Apple', 'Banana', 'Peach']  data.join(','); // return "Mango,Apple,Banana,Peach"

5. 从数组中选择一个元素

对于此任务,我们有多种方式,一种是使用 forEach 组合 if-else 的方式 ,另一种可以使用filter 方法,但是使用forEach  和filter的缺点是:

  1. 鸿蒙官方战略合作共建——HarmonyOS技术社区

  2. 在forEach中,我们要额外的遍历其它不需要元素,并且还要使用 if 语句来提取所需的值。

  3. 在filter 方法中,我们有一个简单的比较操作,但是它将返回的是一个数组,而是我们想要是根据给定条件从数组中获得单个对象。

为了解决这个问题,我们可以使用 find函数从数组中找到确切的元素并返回该对象,这里我们不需要使用if-else语句来检查元素是否满足条件。

const data = [    {id: 1, name: 'Lemon'},    {id: 2, name: 'Mint'},    {id: 3, name: 'Mango'},    {id: 4, name: 'Apple'} ]   const value = data.find(item => item.name === 'Apple') // value = {id: 4, name: 'Apple'}

“怎么用JS数组技巧提高开发技能”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: 怎么用JS数组技巧提高开发技能

本文链接: https://www.lsjlt.com/news/81161.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么用JS数组技巧提高开发技能
    本篇内容介绍了“怎么用JS数组技巧提高开发技能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 随机排列...
    99+
    2024-04-02
  • 怎么运用JS开发技巧
    本篇内容主要讲解“怎么运用JS开发技巧”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么运用JS开发技巧”吧!String Skill对比时间时间个位数形式需补...
    99+
    2024-04-02
  • 如何能提高CSS编写技巧 提高Web前端开发效率
    如何能提高CSS编写技巧?怎么学好Web前端开发?很多人在学习Web前端时,刚开始都会学习HTML和CSS,HTML用于文本内容,CSS用于样式设计,掌握这两部分知识就可以进行简单的页面制作。不过如果耗时过长作品一般未免有些得不偿失,因此你...
    99+
    2023-06-03
  • JS数组实用技巧分享
    本篇内容介绍了“JS数组实用技巧分享”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 删除数组的重复项2...
    99+
    2024-04-02
  • 提高开发效率Vue技巧有哪些
    这篇文章主要讲解了“提高开发效率Vue技巧有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“提高开发效率Vue技巧有哪些”吧!组件(component)的...
    99+
    2024-04-02
  • 提高开发效率的Go语言应用技巧
    掌握Go语言的应用技巧:提升你的开发效率! 随着互联网的快速发展,编程语言也在不断涌现和演进。Go语言作为一种相对较新的语言,以其简洁、高效和强大的特性,逐渐受到了广大开发者的关注和喜爱。那么,如何才能更好地...
    99+
    2024-02-02
    go语言 应用技巧 开发效率 网络编程 标准库
  • 提高开发效率和性能的Vue技巧有哪些
    本篇内容主要讲解“提高开发效率和性能的Vue技巧有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“提高开发效率和性能的Vue技巧有哪些”吧!1. 巧用$attrs和$listeners$att...
    99+
    2023-07-02
  • 提高开发效率的Vue技巧有哪些
    本篇内容主要讲解“提高开发效率的Vue技巧有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“提高开发效率的Vue技巧有哪些”吧!组件(component)的使...
    99+
    2024-04-02
  • 快速提升开发CSS技能的小技巧有哪些
    这篇文章主要介绍快速提升开发CSS技能的小技巧有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!flexbox 内容换行当我们使用 flexbox 布局的时候,默认情况下,在容器宽...
    99+
    2024-04-02
  • 帮你提高开发效率的JavaScript20个技巧
    目录1. 申明和初始化数组2.进行求和、最小值和最大值3. 对字符串、数字或对象的数组进行排序4. 是否需要从一个数组中过滤掉无用的值?5. 为各种条件使用逻辑运算符6. 删除重复的...
    99+
    2024-04-02
  • 使用Golang Facade提高项目开发效率的技巧
    使用Golang Facade可以提高项目开发效率的一些技巧包括:1. 封装复杂的子系统:将复杂的子系统封装在一个简单易用的接口之后...
    99+
    2023-10-08
    Golang
  • PHP数组实战技巧:灵活运用数组操作提升开发效率
    PHP数组作为开发中经常使用的数据结构之一,灵活的运用数组操作可以极大地提升开发效率和代码的可读性,本文将介绍一些实战技巧,并通过具体的代码示例来展示如何灵活运用数组操作。 一、数组的...
    99+
    2024-03-13
    php 数组 操作
  • 提升Web开发性能的技巧有哪些
    本篇内容介绍了“提升Web开发性能的技巧有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、采用反向代...
    99+
    2024-04-02
  • 前端开发中11个JS使用技巧
    这篇“前端开发中11个JS使用技巧”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“前端开发中11个JS使用技巧”,小编整理了以下知识点,请大家跟着小编的步伐一步一步的慢慢理解,接下来就让我们进入...
    99+
    2023-06-06
  • Vue.js + Sass:提高您的前端开发技能
    随着前端开发的飞速发展,掌握 Vue.js 和 Sass 等尖端技术至关重要。本文将详细探讨如何利用这些工具提高您的前端开发技能,帮助您构建高效且美观的 веб-应用程序。 1. Vue.js:强大的前端框架 Vue.js 是一个轻量级、...
    99+
    2024-02-17
    Vue.js Sass 前端开发 CSS预处理器 样式化
  • JS 4个超级实用的小技巧 提升开发效率
    目录1、短路判断2、可选链操作符 ( ? )3、空值合并操作符 ( ?? )4、return终止函数1、短路判断 当只需要简单的if条件时,可使用此方法 ...
    99+
    2024-04-02
  • 如何使用API索引提高Java开发技能?
    Java是一种非常流行的编程语言,许多开发人员都在使用它来构建各种应用程序和系统。使用API索引是提高Java开发技能的一种重要方法。API索引是一个集合,其中包含了许多有用的类和方法,可以帮助Java开发人员更快地编写代码,减少错误和繁琐...
    99+
    2023-08-10
    开发技术 api 索引
  • PHP 框架开发技巧:如何在 Linux 上提高开发效率?
    在 PHP 开发中,使用框架可以大大提高开发效率。然而,在 Linux 上使用 PHP 框架时,也有一些技巧可以帮助提高开发效率。本文将介绍一些在 Linux 上使用 PHP 框架的技巧,帮助您更高效地进行开发。 一、使用 Compose...
    99+
    2023-09-09
    框架 开发技术 linux
  • 如何使用Go开发技术提高Apache并发性能?
    Go语言是一种快速、高效的编程语言,它在网络编程和并发处理方面非常出色。在本文中,我们将介绍如何使用Go语言开发技术来提高Apache的并发性能。 Apache是一个广泛使用的Web服务器,它的并发性能对于高流量的网站来说至关重要。我们可以...
    99+
    2023-08-25
    开发技术 apache 并发
  • 怎么掌握JS高阶编程技巧
    这篇文章主要讲解了“怎么掌握JS高阶编程技巧”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么掌握JS高阶编程技巧”吧!单例设计模式用单独的实例来管理当前事...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作