返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript扩展运算符的学习及应用详情(ES6)
  • 647
分享到

JavaScript扩展运算符的学习及应用详情(ES6)

JavaScript扩展运算符应用JavaScript扩展运算符 2022-11-13 14:11:03 647人浏览 安东尼
摘要

目录学习应用函数参数数组合并解构赋值字符串转换转换数组前言: 扩展运算符是es6新增的一种运算符,他可以帮助我们简化代码,简化操作,所以在开发中是非常常用的,下面我将从学习与应用两个

前言:

扩展运算符是es6新增的一种运算符,他可以帮助我们简化代码,简化操作,所以在开发中是非常常用的,下面我将从学习应用两个方面来带掘友学习扩展运算符。

学习

我们先来学习一下扩展运算符的使用语法

扩展运算符使用形式为...[1,2,3]...加上数组

其作用可以理解成与rest相反的操作,rest参数是在函数中将参数转化为数组形式传进函数内,而扩展运算符是将数组转换至以逗号相隔的参数序列。

let arr = ["a", "b"];
console.log(...arr); // a b

上面我声明了一个数组,通过扩展运算符的方式打印,得到一个参数序列,了解完语法后来主要学习扩展运算符的应用场景

应用

下面我将从函数应用数组合并解构赋值字符串转换转换数组五个方面展开扩展运算符的应用场景。

函数参数

由扩展运算符运算结果的特性,可以将其运用在函数传入参数时

function add(x, y) {
  return x + y;
}
let arr = [1, 2];
add(...arr); // 3

上面我将arr数组搭配扩展运算符传入函数,分别对应参数xy

值得注意的是在有扩展运算符之前,我们是通过使用apply方法将数组作为参数传入函数的,它的使用方式如下,拿上面的add函数举例:

add.apply(null,arr) // 3

因为apply可以改变this指向并传入参数,借此特性可以将数组作为参数。

数组合并

在ES5中的数组合并是通过concat函数来实现的,又或者使用push来实现

let arr_1 = [1, 2, 3];
let arr_2 = [4, 5, 6];
console.log(arr_1.concat(arr_2)); // [ 1, 2, 3, 4, 5, 6 ]

而在ES6中通过扩展运算符进行直接合并,这样的做法可以很好得简洁代码,增加代码的可读性。

console.log([...arr_1,...arr_2]) // [ 1, 2, 3, 4, 5, 6 ]

解构赋值

在一个数组中,我们想要拿到第一个元素外的所有元素,那么在ES5中我们可以这么做:

let arr = [1,2,3,4]
let node = arr[0];
let rest = arr.slice(1)
console.log(rest) // [ 2, 3, 4 ]

而在ES6中我们可以直接使用解构来分割参数

let arr = [1,2,3,4]
let [a,...b] = arr
console.log(a,b) // 1 [ 2 , 3 , 4 ]

字符串转换

可以使用使用解构赋值将字符串转换为数组

console.log([...'猪痞恶霸']) // ['猪', '痞', '恶', '霸']

还可以改造length属性,因为如果字符串内包含Unicode字符,那么直接的length会有问题,所以可以使用扩展运算符转换后拿到正确的length属性

function length(str) {
    return [...str].length
}
console.log(length("\uD83D\uDE80")) // 1
console.log("\uD83D\uDE80".length) // 2

如上代码所示,使用扩展运算符可以避免Unicode长度识别问题

转换数组

我们可以通过使用扩展运算符将伪数组转化为数组,伪数组我们可以理解为类似数组的一个集合,这里简单提一下伪数组。

我们常见的有俩种伪数组,一个是arguments还有一个是DOM的children属性,获取回来的子节点集合。伪数组与数组的区别就是它们的_proto_区别,而普通数组有很多数组的方法,比如说push,shift,map等等,而伪数组却无法使用这些方法。

这就涉及到一个痛点,大家在使用DOM的时候如果想使用数组的一些方法,那怎么办呢?我们就可以先转化为数组再去使用这些方法,下面举一个简单的操作dom例子。

const divs = document.querySelectorAll('div')
const divArr = [...divs]
console.log(divArr)

到此这篇关于javascript扩展运算符的学习及应用详情(ES6)的文章就介绍到这了,更多相关js扩展运算符内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: JavaScript扩展运算符的学习及应用详情(ES6)

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

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

猜你喜欢
  • JavaScript扩展运算符的学习及应用详情(ES6)
    目录学习应用函数参数数组合并解构赋值字符串转换转换数组前言: 扩展运算符是ES6新增的一种运算符,他可以帮助我们简化代码,简化操作,所以在开发中是非常常用的,下面我将从学习与应用两个...
    99+
    2022-11-13
    JavaScript扩展运算符应用 JavaScript扩展运算符
  • es6对象扩展运算符怎么应用
    ES6的对象扩展运算符(`...`)可以用于复制对象、合并对象、传递函数参数等多种应用。 复制对象:使用对象扩展运算符可以非常方...
    99+
    2023-10-25
    es6
  • es6中扩展运算符如何用
    本篇内容介绍了“es6中扩展运算符如何用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • ES6中扩展运算符怎么用
    这篇文章主要介绍了ES6中扩展运算符怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。扩展运算符  ...可以将数组转换为逗号分隔的参数序...
    99+
    2024-04-02
  • ES6扩展运算符如何使用
    这篇“ES6扩展运算符如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“ES6扩展运算符如何使用”文章吧。什么是spre...
    99+
    2023-06-17
  • ES6中的扩展运算符怎么使用
    这篇文章主要讲解了“ES6中的扩展运算符怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“ES6中的扩展运算符怎么使用”吧!ES6的扩展运算符,它的语法...
    99+
    2024-04-02
  • JavaScript扩展运算符怎么用
    小编给大家分享一下JavaScript扩展运算符怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!复制数组我们可以使用展开操作符复制数组,不过要注意的是这是一个...
    99+
    2023-06-14
  • ES6扩展运算符的使用方法示例
    目录什么是spread 和rest运算符数组的扩展运算符rest运算符(收集作用)spread运算符(展开作用)对象的扩张运算符浅克隆深克隆总结什么是spread 和rest运算符 ...
    99+
    2024-04-02
  • 如何正确的使用ES6扩展运算符
    本篇文章给大家分享的是有关如何正确的使用ES6扩展运算符,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。什么是spread 和rest运算符spread和rest运算符在ES6中...
    99+
    2023-06-20
  • ES6扩展运算符的使用方法有哪些
    这篇文章主要介绍“ES6扩展运算符的使用方法有哪些”,在日常操作中,相信很多人在ES6扩展运算符的使用方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”ES6扩展运算符...
    99+
    2024-04-02
  • ES6扩展运算符的理解与使用场景
    目录1、替代apply方法,一般在函数调用时处理参数2、剩余参数(rest运算符),主要针对函数形参3、数据连接、合并4、数组和对象的拷贝5、字符串转数组6、在函数调用时使用拓展运算...
    99+
    2024-04-02
  • JavaScript中如何使用扩展运算符
    这篇文章给大家介绍JavaScript中如何使用扩展运算符,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。个人对…常用方法的理解…作为扩展运算符这里指的扩展是针对数组或字符串或伪数组(就...
    99+
    2024-04-02
  • JavaScript扩展运算符的简写方法
    这篇文章主要介绍JavaScript扩展运算符的简写方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!扩展运算符简写扩展运算符有几种用例让JavaScript代码更加有效使用,可以用来代替某个数组函数。简写:不像co...
    99+
    2023-06-27
  • JavaScript中运算符与数组扩展详细讲解
    目录运算符扩展运算符指数运算符链判断运算符Null判断运算符逻辑赋值运算符数组扩展方法Array.from()Array.of()copyWithin()find()fill()fl...
    99+
    2022-11-13
    JS运算符与数组扩展 JS数组扩展 JS运算符
  • JavaScript中如何使用扩展运算符展开对象
    这篇文章主要为大家展示了“JavaScript中如何使用扩展运算符展开对象”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript中如何使用扩展运算符展开对象”这篇文章吧。展开对象co...
    99+
    2023-06-04
  • JavaScript展开运算符和剩余运算符的区别详解
    目录什么是剩余运算符?剩余运算符在JavaScript函数中是如何工作的?注意!不能在包含剩余参数的函数体中使用"use strict"剩余运算符在参数解构中是如...
    99+
    2024-04-02
  • JS ES6展开运算符的几个妙用
    目录1. 添加属性2. 合并多个对象3. 移除对象属性4.动态移除属性5. 调整属性顺序6. 设置属性默认值7: 属性重命名8. 还有更秀的操作1. 添加属性 复制对象的同时,为其添...
    99+
    2024-04-02
  • javascript中怎么提高扩展运算符的性能
    这篇“javascript中怎么提高扩展运算符的性能”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“javascript中怎么提高扩展运算符的性能”,小编整理了以下知识点,请大家跟着小编的步伐一...
    99+
    2023-06-06
  • JavaScript ES6解构运算符的理解和运用
    目录前言解构符号的作用使用方法解构赋值的应用浅谈应用提取json数据可扩展运算符...交换变量值总结前言 最近一直在学JavaScript,看到了ES6中的解构符号,觉得这个给我们...
    99+
    2024-04-02
  • C++学习之算术运算符使用详解
    目录1. 前言2. 运算符种类3. 算术运算符3.1 功能描述3.2 运算符重载问题3.3 两数相除的问题3.4 关 于/和%运算符的正、负问题3.5 数据溢出问题3.6 类型转换3...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作