【JS代码优化二】ES6 数组和对象篇

简介: 【JS代码优化二】ES6 数组和对象篇

Vue3 + Vite + VueRouter + Pinia + Axios + Element Plus + 项目实战(持续更新中…)

序:如何让代码看起来更优雅?代码是由文字堆叠起来的可以被机器执行的程序。它记载着相关信息(状态)、表达相关的情绪(函数),所以如何能够写出简洁、优雅、健壮、可维护性强的程序至关重要。本系列笔记的目的,就是带着大家如何实现更有效、更优雅的编程。笔记涵盖:运算符、流程语句、设计模式、ES6 新增方法等多个方面。

我们都知道 ES6+ 新增了很多新特性,它们使得在很多场景的应用上变得更加健壮(如:let、const关键字的出现),更像一门面向对象语言(如:类,继承这些关键字的出现),处理起数据更加的简洁和方便(如:数组 map、filter、from等方法的出现)等等,一切都是为了让程序变得更有可读性、可维护性。这里我们就来讲一下数组中新增函数的应用场景。

数字化管理平台

Vue3+Vite+VueRouter+Pinia+Axios+ElementPlus教程

权限系统-商城

个人博客地址

1. Array.from()

这个方法用于将类数组对象(NodeList 节点列表、String 字符串、arguments 参数对象、HTMLCollection 元素列表等具有 length 属性的对象)转为真正的数组。

在这个方法之前,我们都是使用 apply 或 call 方法实现。

1.1 对象

apply 方式

let result = Array.apply(null, { length: 10 }).map((_, index) => {
    return {
        id: index,
        value: index + 1
   }
})

Array.from 方式

let result = Array.from({length: 99})

72f030b38643478489d46281c6feed9d.png

1.2 String 字符串

call 方式

let str = "Hello World"
let result = [].slice.call(str)

Array.from方式

let result = Array.from(str)

7be04e6e4f8041d29061e5018219b7f7.png

HTMLCollection 元素列表、NodeList 节点列表、Arguments 参数列表这些伪数组处理方式相同。参数求和、页面DOM排序等应用场景。

1.3 Array.from 第二个参数

Array.from 第二个参数类似 “Array.prototype.map” 可以用于处理数据,这样看来就比 apply 功能更加强大。

let numStr = "123456789"
let result = Array.from(numStr, v => v * 2)

ee23b4dbc3f64a2a9296858a69309840.png

2. Array.of

初学者在学习 Array 内置数组对象的时候,都感觉创建对象时,有一个很神奇的地方,就是你给 Array 传递不同的参数,得到不同的结果。

传递一个数字:得到的是一个长度为指定数字长度的空数组

let arr = new Array(10)

0db22076b4e14e5c9dcfcef0fe4cb112.png

传递一个非数字:长度为1,元素就是当前这个参数

let arr = new Array(true)
let arr1 = new Array("Hello")
let arr2 = new Array(new Date())
let arr3 = new Array({a:1,b:2})
let arr4 = new Array([10,20,30])

a0ffc0c776dc4d1ebd30f237ed99e057.png

传递两个以上数字类型或混合类型:得到的是以两个值为数组元素,长度为 2 的数组

let arr = new Array(10, 20)

9c90a257fb764a50b166968bf085b0a7.png

Array.of 的出现弥补了 Array 的不足,使得我们创建数组对象时,传入的任何类型参数,都是数组元素

let arr = Array.of(10)

f4315c7889aa4d939aa5499dc94a16ee.png

let arr = Array.of(10,20)
let arr1 = Array.of("Hello")
let arr2 = Array.of("Hello", true, {a:1, b:2})

453c86712fa54a77b4d260637f327dcd.png

3. Array.prototype.at

通常情况下,访问数组后面几个元素的做法是访问 length 并将其减去从末端开始的相对索引(因为中括号的方式不支持负索引)。例如,array[array.length - 1]。

而 at 方法的出现允许使用相对索引(支持负索引),因此上面的示例可以简化为 array.at(-1)。

let arr = [1, 2, 3, 4, 5, 6, 7, 8, 9]
let ele1 = arr[0]; // 1
let e1 = arr.at(0); // 1
let elelast = arr[arr.length - 1]; // 9
let elast = arr.at(arr.length - 1); // 9
let el = arr.at(-1); // 9
let elel = arr[-1]; // undefined
let ef = arr.at(); // 1 不传参默认取第一个元素
let els = arr.at(-2); // 8

4. Array.prototype.includes

includes() 方法用来判断一个数组是否包含一个指定的值,根据情况,如果包含则返回 true,否则返回 false。

可以用其来做逻辑或运算的简化操作

逻辑或运算

let type = 1
if (type === 1 || type === 5 || type === 12) {
  console.log(type * 10)
}

includes 实现

if ([1, 5, 12].includes(type)) {
  console.log(type * 10)
}

利用 Set 去重

数组去重大家很熟悉,网上搜索出来的有 N 多种实现方案,大多数传统方案都是采用数组遍历的方式实现,像下面这样:

var arr=[1,2,3,4,5,3,7,8];
function noRepeat(arr){
    var newArr = [];
    for(var i = 0; i < arr.length; i++){
        if(newArr.indexOf(arr[i]) == -1){
            newArr.push(arr[i]);
        }
    }
    return newArr;
}
var result = noRepeat(arr);

Set对象是值的集合,你可以按照插入的顺序迭代它的元素。Set 中的元素只会出现一次,即 Set 中的元素是唯一的。

const numbers = [2,3,4,4,2,3,3,4,4,5,5,6,6,7,5,32,3,4,5]
console.log([...new Set(numbers)])
// [2, 3, 4, 5, 6, 7, 32]

简单吧!

应用示例演示一:求和函数

arguments 对象 + for 循环

function sum () {
  let res = 0
  for (let i = 0; i < arguments.length; i++) {
    res += arguments[i]
  }
  return res
}
sum(10)
sum(10, 20)
sum(10, 20, 30)

arguments 对象 + Array.from(或者 apply、call)+ reduce

function sum () {
  return Array.from(arguments).reduce((t,n) => t + n, 0)
}
sum(10)
sum(10, 20)
sum(10, 20, 30)

es6有arguments,但箭头函数是不识别arguments的,所以用rest(剩余参数)来取代arguments;剩余参数直接就固定到数组里了,而arguments是类数组(本质是个对象),还需要转换。剩余参数语法允许将一个不定数量的参数表示为一个数组,不定参数定义方式,这种方式很方便的去声明不知道参数情况下的一个函数。

… 不定参数

let sum = (...args) => {
  console.log(args)
  let res = 0;
  for (let i = 0; i < args.length; i++) {
    res += args[i]
  }
  return res
}
sum(10)
sum(10, 20)
sum(10, 20, 30)

… 拓展运算符 + reduce 求和

let sum = (...args) => {
  return args.reduce((t,n) => t + n, 0)
}
sum(10)
sum(10, 20)
sum(10, 20, 30)


相关文章
|
11月前
|
JavaScript 前端开发
如何在 JavaScript 中使用 __proto__ 实现对象的继承?
使用`__proto__`实现对象继承时需要注意原型链的完整性和属性方法的正确继承,避免出现意外的行为和错误。同时,在现代JavaScript中,也可以使用`class`和`extends`关键字来实现更简洁和直观的继承语法,但理解基于`__proto__`的继承方式对于深入理解JavaScript的面向对象编程和原型链机制仍然具有重要意义。
|
6月前
|
编解码 JavaScript 前端开发
【Java进阶】详解JavaScript的BOM(浏览器对象模型)
总的来说,BOM提供了一种方式来与浏览器进行交互。通过BOM,你可以操作窗口、获取URL、操作历史、访问HTML文档、获取浏览器信息和屏幕信息等。虽然BOM并没有正式的标准,但大多数现代浏览器都实现了相似的功能,因此,你可以放心地在你的JavaScript代码中使用BOM。
187 23
|
11月前
|
Web App开发 JavaScript 前端开发
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
|
7月前
|
JavaScript 前端开发 API
JavaScript中通过array.map()实现数据转换、创建派生数组、异步数据流处理、复杂API请求、DOM操作、搜索和过滤等,array.map()的使用详解(附实际应用代码)
array.map()可以用来数据转换、创建派生数组、应用函数、链式调用、异步数据流处理、复杂API请求梳理、提供DOM操作、用来搜索和过滤等,比for好用太多了,主要是写法简单,并且非常直观,并且能提升代码的可读性,也就提升了Long Term代码的可维护性。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
7月前
|
JavaScript 前端开发 网络架构
ES6解构赋值详解;全面掌握:JavaScript解构赋值的终极指南
解构赋值是一个强大且灵活的工具,它使得从数组和对象中提取数据变得更加简单和直观。通过掌握解构赋值的基本语法和实践,你可以写出更加简洁、可读性更强的代码。在实际项目中,解构赋值广泛应用于函数参数处理、变量交换、嵌套结构操作等场景,极大地提升了代码的灵活性和简洁度。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
7月前
|
数据采集 JavaScript 前端开发
JavaScript中通过array.filter()实现数组的数据筛选、数据清洗和链式调用,JS中数组过滤器的使用详解(附实际应用代码)
用array.filter()来实现数据筛选、数据清洗和链式调用,相对于for循环更加清晰,语义化强,能显著提升代码的可读性和可维护性。博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
11月前
|
存储 JavaScript 前端开发
JS的ES6知识点
【10月更文挑战第19天】这只是 ES6 的一些主要知识点,ES6 还带来了许多其他的特性和改进,这些特性使得 JavaScript 更加现代化和强大,为开发者提供了更多的便利和灵活性。
226 58
|
11月前
|
JSON 前端开发 JavaScript
JavaScript中对象的数据拷贝
本文介绍了JavaScript中对象数据拷贝的问题及解决方案。作者首先解释了对象赋值时地址共享导致的值同步变化现象,随后提供了五种解决方法:手动复制、`Object.assign`、扩展运算符、`JSON.stringify`与`JSON.parse`组合以及自定义深拷贝函数。每种方法都有其适用场景和局限性,文章最后鼓励读者关注作者以获取更多前端知识分享。
159 1
JavaScript中对象的数据拷贝
|
11月前
|
JavaScript 前端开发 安全
ECMAScript 6(以下简称 ES6)的出现为 JavaScript 带来了许多新的特性和改进,其中 let 和 const 是两个非常重要的关键字。
ES6 引入了 `let` 和 `const` 关键字,为 JavaScript 的变量管理带来了革新。`let` 提供了块级作用域和暂存死区特性,避免变量污染,增强代码可读性和安全性;`const` 用于声明不可重新赋值的常量,但允许对象和数组的内部修改。两者在循环、函数内部及复杂项目中广泛应用,有助于实现不可变数据结构,提升代码质量。
149 5
|
11月前
|
JavaScript 前端开发 图形学
JavaScript 中 Math 对象常用方法
【10月更文挑战第29天】JavaScript中的Math对象提供了丰富多样的数学方法,涵盖了基本数学运算、幂运算、开方、随机数生成、极值获取以及三角函数等多个方面,为各种数学相关的计算和处理提供了强大的支持,是JavaScript编程中不可或缺的一部分。