NoteZ_技术博客 NoteZ_技术博客
🏠 首页
  • 📚 Web技术
  • 📋 Npm笔记
  • 📑 Markdown
  • 📄 Git笔记
  • 📝 Nginx文档
  • 📓 Linux文档
  • 📖 技术文档
  • 📜 其他文档
  • 🧊 NodeJs
  • 🎡 Express
  • 🔥 Rust
  • 🎉 Koa2
  • 🍃 MongoDB
  • 🐬 MySql
  • 🥦 Oracle
  • 🍁 Python
  • 🍄 JavaScript
  • 🌰 CSS
  • 🧄 HTML
  • 🥑 Canvas
  • 🌽 Nuxt
  • 🍆 React
  • 🥜 Vue
  • 🧅 TypeScript
  • 🌶️ AI
  • 📘 分类
  • 📗 标签
  • 📙 归档
⚜️ 在线编辑 (opens new window)
  • 📁 站点收藏
  • 📦 前端组件库
  • 📊 数据可视化
  • 🌈 开源插件
  • 🎗️ 关于我
  • 🔗 友情链接
GitHub (opens new window)

NoteZ_技术博客

前端界的小学生
🏠 首页
  • 📚 Web技术
  • 📋 Npm笔记
  • 📑 Markdown
  • 📄 Git笔记
  • 📝 Nginx文档
  • 📓 Linux文档
  • 📖 技术文档
  • 📜 其他文档
  • 🧊 NodeJs
  • 🎡 Express
  • 🔥 Rust
  • 🎉 Koa2
  • 🍃 MongoDB
  • 🐬 MySql
  • 🥦 Oracle
  • 🍁 Python
  • 🍄 JavaScript
  • 🌰 CSS
  • 🧄 HTML
  • 🥑 Canvas
  • 🌽 Nuxt
  • 🍆 React
  • 🥜 Vue
  • 🧅 TypeScript
  • 🌶️ AI
  • 📘 分类
  • 📗 标签
  • 📙 归档
⚜️ 在线编辑 (opens new window)
  • 📁 站点收藏
  • 📦 前端组件库
  • 📊 数据可视化
  • 🌈 开源插件
  • 🎗️ 关于我
  • 🔗 友情链接
GitHub (opens new window)
  • JavaScript笔记

    • ajax如何解决跨域问题
    • async与await语法
    • Axios 文件下载实现进度条功能
    • Axios 的各种请求方式及传参格式总结
    • axios简单使用
    • CommonJS与ES6 Module的导入与导出之间的区别
    • ES6 中 export,export default 和 import 区别及用法
    • Javascript - 如何循环遍历getElementsByClassName返回的所有DOM元素
    • JavaScript 实现 charts 缩放比例尺
    • javaScript 实现将文件流下载文件保存到本地
    • JavaScript 数组对象去重方法
    • JavaScript 生成 uuid
    • JavaScript 解析 get 请求 url 参成对象
    • JavaScript判断字符串中是否包含某个字符串
    • JavaScript判断是否为移动端浏览器
    • JavaScript复制内容到剪贴板的两种常用方法
    • JavaScript实现单词首字母大写的方法总汇
    • JavaScript对时间(time)、日期(date)格式转换
    • JavaScript数组去重方法总结
    • JavaScript数组类型(Array)操作方法汇总
      • 关于数组
      • join() 转换方法 (不改原数组)
      • 栈方法,后进先出 push() 、pop() (改变原数组)
      • 队列方法,先进先出 push()、shift() 、unshift() (改变原数组)
      • 重排序方法 reverse() 反转 sort() 排序 (改变原数组)
      • 操作方法 concat() 拼接,slice() 切片,splice() 移接
      • 位置方法 indexOf()、lastIndexOf()
      • 迭代方法 every()、some() 、filter()、map() 、forEach() (都不会改变原数组)
      • 归并方法 reduce() reduceRight()
    • JavaScript浅度和深度复制的实现方法
    • js 中的 ES5 面向对象
    • js 中的 ES6 面向对象
    • js 中的 new 命令原理
    • js 实现 iframe通信
    • js 实现将文本复制到粘贴板
    • js 异步操作
    • js 数组转为树形(tree)结构
    • js 文件分片上传
    • js 统计数组中元素的重复次数
    • JS 选中文本输入框的部分文本内容
    • js 面向对象总结
    • Js中的forEach()、map()、$.each()和$.map()之间异同
    • js中的多种数组去重性能对比总结
    • js判断移动端还是pc端
    • JS如何监听div的resize事件
    • js实现格式化JSON数据方法
    • js实现防抖与节流函数
    • Js将滚动条(scrollbar)保持在最底部的方法
    • JS异步编程进化之路
    • JS数组改变元素位置(互换、置顶、上移、下移)
    • js数组的简单使用
    • js文件单位大小转换
    • JS获取和修改url参数
    • JS获取浏览器信息
    • js获取浏览器可视区或页面大小的兼容性总结
    • JS读取本地文本文件(兼容各种浏览器)
    • js随机打乱数组
    • Promise 中的 async 与 await 特点
    • Promise封装请求
    • qs.stringify 的基本用法
    • Web worker 使用方法
    • window.open之浏览器新窗口打开
    • 使用 js 实现保存 .tree 文件到本地
    • 使用 JS 将数字转化成千分位
    • 使用 js 快速计算文件 hash 值
    • 使用 js 进行Base64编码、解码(js-base64)
    • 使用 setTimeout 解决 setInterval 计时器不准的问题
    • 使用js在树形(tree)结构中找到子节点的父级路径
    • 使用JS如何判断远程网络图片地址是否失效
    • 使用js操作浏览器cookie的设置,读取,删除
    • 使用JS解决PC端页面适配方案
    • 使用js递归生成树形结构
    • 使用原生js(input type = file)上传图片(Base64)限制大小、类型判断、像素判断
    • 关于JavaScript 数组的复制解析总结
    • 关于JavaScript数组方法使用总结
    • 内置对象
    • 前端 DOM 总结
    • 前端 js 基础总结
    • 前端使用 jszip 解压 .zip 文件获取 file 格式文件
    • 前端各种事件总结
    • 前端常用的JS(代码片段)小工具方法总结
    • 前端登录界面常用的JS小工具方法总结
    • 十六(16)进制与rgb颜色转换
    • 原生 JavaScript 实现 div 随意拖拽原生 JavaScript 实现 div 随意拖拽
    • 原生 JS 实现页面树形(tree)菜单展示功能
    • 原生js实现 table表格列宽拖拽
    • 原生js获取iframe中dom元素或父级元素
    • 如何使用 file-saver 导出文件到本地?
    • 如何使用js将目录路径list转成tree树结构
    • 实现对localStorage、sessionStorage高级封装
    • 将一维数组按指定长度转为二维数组
    • 将网站设为主页以及加入收藏功能实现方法
    • 总结 3 种 HTML 转 PDF 导出的方案
    • 比typeof运算符更准确的js类型判断
    • 浏览器模型
    • 监听滚动条事件-返回顶部的方法
    • 简析JavaScript中的事件委托问题
    • 返回顶部的通用Js方法
    • 非常实用的Js代码工具片段
    • JS_根据鼠标位置缩放元素、拖拽
    • js_登录验证码绘制
    • JS-以鼠标位置为中心的滑轮缩放-图片
    • js生成目录并实现目录节点跟随滚动高亮
    • 使用js实现标题跳转与复制实现方法
    • 使用原生js动态实现文件的上传功能
    • 使用原生js提取md中的图片信息
    • 3d-force-graph使用方法
    • js 前端(web)浏览器端读取文件目录
    • 原生js监听窗口大小变化
    • JS 中 Promise 用法(简要总结)
  • CSS笔记

  • HTML笔记

  • Canvas笔记

  • Nuxt笔记

  • React笔记

  • Vue笔记

  • TypeScript笔记

  • AI相关笔记

  • 开发文档
  • JavaScript笔记
NoteZ
2019-12-01
目录

JavaScript数组类型(Array)操作方法汇总

# 关于数组

  • 数组的length属性不是只读的

检测数组

value instanceof Array
Array.isArray(value)
1
2

转换方法

  • toLocaleString() 与toString()相同
  • toString() 返回数组中每个值的字符串形式用逗号分隔拼接而成的字符串
  • valueOf() 返回数组本身

# join() 转换方法 (不改原数组)

接收一个参数,用作分隔符的字符串,然后返回包含所有数组项的字符串。

var arr = ['red','blue','green']
var arrStr = arr.join('|') // "red|blue|green"

arr.join() // "red,blue,green"
arr.join('') // "redbluegreen"
1
2
3
4
5

# 栈方法,后进先出 push() 、pop() (改变原数组)

  • push() 向数组末尾添加成员,返回总长
  • pop() 移除数组末尾一个成员,返回该成员

# 队列方法,先进先出 push()、shift() 、unshift() (改变原数组)

  • shift() 移除数组首个成员,返回该成员

  • unshift() 在数组前面添加成员,返回总长

push()和shift() 形成队列方法

unshift和pop() 形成反方向队列方法

# 重排序方法 reverse() 反转 sort() 排序 (改变原数组)

  • reverse() 反转数组项的顺序
  • sort() 接收一个函数作为参数,函数接收两个参数。
    • 自定义排序:函数内,如果第一个参数应该位于第二个之前,则手动返回一个负数,如果两个参数相等,手动返回0,如果第一个参数应该位于第二个参数之后,则手动返回一个正数。
// 升序
arr.sort(function(a,b){
    if(a < b) {
        return -1
    } else if (a > b) {
        return 1
    } else {
        retunr 0
    }
})
1
2
3
4
5
6
7
8
9
10

简写:

arr.sort((a,b) => {
    return a-b // 升序, b-a 降序
})
1
2
3

# 操作方法 concat() 拼接,slice() 切片,splice() 移接

  • concat() 拼接数组 (不改原数组)

    var arr1 = ['a','b']
    var arr2 = arr1.concat('c','d') // ['a','b','c','d']
    
    1
    2
  • slice() 切片(不改原数组)

    • slice(起始位置 [, 结束位置]) 返回起始位置到结束位置的成员,不包含结束位置。
    var arr1 = [1,2,3,4,5]
    var arr2 = arr1.slice(1,3) // [2,3]
    var arr3 = arr1.slice(2) // [3,4,5]
    
    1
    2
    3
  • splice() 移接 (改变原数组)

    • splice(起始位置, 要删除的个数,要插入的项)
      • 要插入的项 可以有0个或多个
    • splice() 始终返回一个数组,该数组成员中包含原始数组中被删除的项,如果没有则返回空数组。
    • 数组最强大的方法,可用于删除、插入、替换操作
    arr = [1,2,3,4]
    arr.splice(1,1) // [2]
    arr // [1,3,4]
    
    
    arr = [1,2,3,4]
    arr.splice(2,0,'a') // []
    arr // [1,2,'a',3,4]
    
    arr = [1,2,3,4]
    arr.splice(3,1,'a') // [4]
    arr // [1,2,3,'a']
    
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12

# 位置方法 indexOf()、lastIndexOf()

  • 查找项的位置,没有则返回-1
  • indexOf() 从前面开始找,lastIndexOf() 从后面开始找

# 迭代方法 every()、some() 、filter()、map() 、forEach() (都不会改变原数组)

  • 5个迭代方法,每个方法都接收两个参数:

    • 在每项上运行的函数
    • 运行函数的作用域对象
  • 函数接收三个参数:

    • 数组项的值
    • 该项的索引
    • 数组本身
  • every() 如果函数对每项都返回true,则返回true

    • 例:判断数组每一项是否都大于2

      var numbers = [1,2,3,2,1]
      var result = numbers.every((item,index,array) => {
          return item > 2
      })
      result // false
      
      1
      2
      3
      4
      5
  • some() 如果函数对任一项返回true,则返回true

    • 例:判断数组是否包含大于2的值

      var numbers = [1,2,3,2,1]
      var result = numbers.some((item,index,array) => {
          return item > 2
      })
      result // true
      
      1
      2
      3
      4
      5
  • filter() 返回函数会返回true的项组成的数组

    • 例:过滤掉数组中小于等于2的数

      var numbers = [1,2,3,4,5]
      var result = numbers.filter((item,index,array) => {
          return item >2
      })
      result // [3,4,5]
      
      1
      2
      3
      4
      5
  • map() 返回每次函数调用的结果组成的数组

    • 例:给数组每一项乘以2

      var numbers = [1,2,3,4,5]
      var result = numbers.map((item,index,array) => {
          return item * 2
      })
      result // [2,4,6,8,10]
      
      1
      2
      3
      4
      5
  • forEach() 循环数组每一项,没有返回值

    • 例:循环每一项

      var numbers = [1,2,3,4,5]
      numbers.forEach((item,index,array) => {
          // 做一些操作
      })
      
      1
      2
      3
      4

# 归并方法 reduce() reduceRight()

  • reduce() 归并为

  • reduceRight() 从右边归并

  • 这两个方法都会迭代数组所有项,然后构建一个最终结果并返回

  • 方法接收两个参数: 每一项上调用的函数,归并基础的初始值

  • 函数接收4个参数:前一个的值、当前值、当前值的索引、数组对象

  • 例:求数组每一项之和

    var numbers = [1,2,3,4,5]
    var result = number.reduce((prev,cur,index,arr) => {
        return prev + cur
    })
    result // 15
    
    1
    2
    3
    4
    5
  • reduce()方法,第一次执行函数时,prev是数组的第一项,cur是数组的第二项

#JavaScript
上次更新: 2024/01/30, 00:35:17
JavaScript数组去重方法总结
JavaScript浅度和深度复制的实现方法

← JavaScript数组去重方法总结 JavaScript浅度和深度复制的实现方法→

最近更新
01
Gitea数据备份与还原
03-10
02
Linux 中使用 rsync 同步文件目录教程
03-10
03
Linux 使用 rsync 互相传输同步文件的简单步骤
03-08
更多文章>
Theme by Vdoing | Copyright © 2019-2025 NoteZ,All rights reserved | 冀ICP备2021027292号-1
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式