JS数组方法

本文深入解析JavaScript数组的各种方法,包括pop、push、shift、unshift、slice、splice、sort、reverse、indexOf、lastIndexOf、concat、join、map、forEach等,详细说明了它们的功能、参数、返回值及使用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

js数组方法

  • 1.有length 有索引

var ary=[12,3,4]

  • 1.pop,想删除两项时,必须使用两次,删完一项在删一项
    • 1.删除数组最后一项
    • 2.不需要传参
    • 3.pop()返回值是删除的哪一项
    • 4.原有数组发生改变
   console.log(ary)
      ary.pop();//删除数组最后一项
      console.log(ary.pop())
      console.log(ary)
  • push新增
    • 像数组末尾新增一项或多项
    • 需要传参
    • 返回值是新数组的length
    • 原有数组发生改变
   ary.push(100,123,57,8)
    console.log(ary.push([1,3]))//不可以新增数组
    console.log(ary)
  • shift 删除数组第一项
    • 不需要传参
    • shift()返回值是删除的哪一项
    • 原有数组发生改变
   ary.shift()//删除数组第一项
    console.log(ary.shift())
    console.log(ary)
  • unshift 像数组开头新增一项或多项
    • 需要传参
    • 返回值是新数组的length
    • 原有数组发生改变
   ary.unshift(59)
    console.log( ary.unshift())
    console.log(ary)
  • slice 截取
    • 参数slice(m,n)从索引m开始,到n索引结束,但不包括索引n
    • 参数slice(m)从索引m开始,到最后的索引结束
    • 参数slice()克隆一个一模一样的数组
    • 参数slice(-1)支持负数让ary.length和负数相加,在截取,得到的结果就是要截取的开始项
    • m>n:[]
    • m>n返回值空数组;
    • 原有数组不发生改变
    • 返回值为截取的新数组
 ary.slice(0,1)
    console.log(ary.slice(-1))
console.log(ary)
var f=[1,3,5,23,5,66]
console.log(f)
console.log(f.slice(3,-1))
//[23, 5]从索引3开始到索引(length+(-1))结束,但不包括(length+(-1))
console.log(f.slice(2,-2))// [5, 23]
console.log(ary)
ary.slice(1,-1);
console.log(ary.slice(1,-1))
  • splice 删除数组的某几项
    • 参数,从索引m开始删除n项[splice(m,n)]
    • 3.被删除的几项组成一个新的数组,原有数组发生改变
    • splice(m),从索引m开始把m索引后的都删除掉
    • splice(0),全部删除
    • splice(-m),-m和length相加的的结果就是删除的开始项,到末尾都删除
  • splice(-m,n),-m和length相加的的结果就是删除的开始项索引,删除n项
  • splice(m,x,n):从索引m开始,删除x项。用n替换,当x为0时在m前加上n
  • splice(m,x,n,c):从索引m开始,删除x项。用n,c替换,当x为0时在m前加上n,c
   var ary = [1, 2, 34, 4, "3"];
    console.log(ary)
    console.log(ary.splice(-4,2))//[2, 34]
    console.log(ary.splice(-5,2))//[1, 2]
    console.log(ary)
  • sort 排序
  • 从小道大
ary.sort(function(a,b){
      //根据函数返回值的正负判断是否进行交换
      return a-b;
  })
  console.log(ary)
  • 从大到小
 ary.sort(function(a,b){
      return b-a;
  })
  console.log(ary)
  • reverse 将数组成员位置颠倒过来
 ary.reverse()
  • indexOf
  • 返回值是索引
  • 检测数组成员在数组中第一次出现的位置
  var ary1=[1,2,3,3,4]
    ary1.indexOf(3)
    ary1.indexOf(9)
    ary1.indexOf(3,1) //1:代表索引开始检测的位置
    //indexOf(m,n)//从索引n开始检测m第一次出现的地方
    console.log(ary1.indexOf(3))//2
    console.log(ary1.indexOf(3,1))

lastIndexOf

  • 返回值是索引
  • 检测数组成员在数组中最后一次出现的位置
  • 如果校验的数组成员不存在返回值为-1
  • 原有数组不发生改变
var ary2=[1,2,3,3,4]
    ary2.lastIndexOf(3)
    console.log(ary1.lastIndexOf(3))//3
    console.log(ary1.lastIndexOf(30))//-1
    console.log(ary1.lastIndexOf())//-1
  • concat:数组的连接
    • 放在数组的后面,返回值为数组拼接后的新数组
    • 原数组不改变
    • 也可以基于空数组拼接,空数组不占据内容的位置
 console.log([].concat(ary,[1,2,3]))
     console.log(ary)//["3", 4, 34]
     console.log(ary.concat())//["3", 4, 34]
    //concat():克隆一个数组
  • 跟push的区别:
    • push不可以新增数组,而concat不仅可以拼接数也可以拼接数组
 ary1.concat([12,13,12,13])
    console.log( ary1.concat([12,13,12,13]))//[1,2,3,3,4,12,13,12,13]
    console.log(ary1)//[1,2,3,3,4]
  • join
    • 需要参数
    • 获取到数组的每个成员然后按照给的参数连接到一块,成为一个字符串
    • 原数组不改变
    • 返回一个连接在一起的字符串
ary1.join("+")
   console.log(ary1.join("+"))//"1+2+3+3+4"
   ary1.join("")
   console.log(ary1.join(""))//"12334"
   ary1.join(" ")
   console.log(ary1.join(" "))//"1 2 3 3 4"
   ary1.join("1")
   console.log(ary1.join("1"))//"112131314"
   ary1.join("爱")
   console.log(ary1.join("爱"))//"1爱2爱3爱3爱4"
  • map
  ary1.map(function(item,index,all){
       // console.log(item);//代表数组的每一项
       // console.log(index);//数组成员的索引
       // console.log(all);//所有的数组成员,代表原数组,数组成员有几项就执行几次
       // console.log(all===ary1);//true(5)数组成员有几项就执行几次
    
       // all[index]=item+1//每个数组成员都加上1
       all[index]="<li>"+item+"</li>"//        
   })
   console.log(ary1)

   var a=[1,2,3,3];
   a.map(function(item,index,all){
       a[index]=item+1
   })
   console.log(a)
  • forEach

ary2.forEach(function(item,index,all){
// console.log(item);//代表数组的每一项
// console.log(index);//数组成员的索引
// console.log(all);//所有的数组成员,代表原数组,数组成员有几项就执行几次
return 100; //forEach没有返回值
})
console.log(ary2)


- **`tostring()`**

console.log(ary1)//
console.log(ary1.toString())//
console.log(ary1)





<think>我们参考了多个引用中关于JavaScript数组方法的内容,现在需要给用户提供一份详细的JavaScript数组方法详解和使用指南。我们将按照常见数组方法分类,并给出说明、语法、参数、返回值、是否改变原数组以及示例。注意:根据引用内容,我们会特别关注slice、join、forEach、sort、splice等方法,同时补充其他常用方法。内容结构:1.数组方法分类(根据是否改变原数组)2.每个方法的详细说明(包括方法的功能、语法、参数、返回值、是否改变原数组、示例代码)注意:在回答中,行内代码用`code`表示,但根据要求,行内数学表达式才用$...$,这里我们不需要数学表达式,所以全部用代码块或行内代码块。由于用户要求独立公式单独用$$...$$,但这里没有,所以不用。我们将分为两部分:第一部分:不改变原数组方法(例如:slice,join,concat等)第二部分:改变原数组方法(例如:splice,push,pop,sort,reverse等)同时,我们也会提到一些ES6新增的方法(如map,filter,reduce等),尽管引用中没有详细提到,但为了完整性,我们会简要说明。但是要注意:用户引用的内容中提到了slice,join,forEach,sort,splice,因此这些是重点。开始组织内容:</think> 根据提供的引用内容,以下是 JavaScript 数组方法的详细解析与使用指南,涵盖核心方法的使用场景和注意事项: ### 一、核心数组方法详解 1. **`slice(start, end)`** - **功能**:截取数组中指定区间的元素生成新数组 - **参数**: `start`:起始索引(包含) `end`:结束索引(不包含) - **返回值**:新数组 - **是否改变原数组**:❌ ```javascript const arr = ["a", "b", "c", "d", "e"]; const res = arr.slice(1, 4); // ["b", "c", "d"] ``` 2. **`splice(index, howmany, item1, ...)`** - **功能**:删除/插入元素 - **参数**: `index`:起始位置 `howmany`:删除数量(0表示不删除) `item1...`:插入的新元素 - **返回值**:被删除元素组成的数组 - **是否改变原数组**:✅ ```javascript const arr = [1, 2, 3, 4]; arr.splice(1, 2, "x", "y"); // 删除2个元素后插入 // arr变为 [1, "x", "y", 4] ``` 3. **`forEach(callback)`** - **功能**:遍历数组元素 - **参数**:回调函数 `(value, index, array) => {}` - **返回值**:undefined - **是否改变原数组**:取决于回调操作 ```javascript const arr = [1, 2, 3]; arr.forEach((val, idx) => console.log(val * idx)); // 输出: 0, 2, 6 ``` 4. **`sort([compareFunction])`** - **功能**:数组排序(默认按字符编码排序) - **参数**:可选比较函数 `(a,b) => a-b`(升序) - **返回值**:排序后的数组 - **是否改变原数组**:✅ ```javascript const nums = [23, 65, 13]; nums.sort((a,b) => a - b); // [13, 23, 65] ``` 5. **`join(separator)`** - **功能**:将数组连接为字符串 - **参数**:分隔符(默认逗号) - **返回值**:字符串 - **是否改变原数组**:❌ ```javascript ["a", "b", "c"].join("-"); // "a-b-c" ``` ### 二、特殊技巧应用 1. **类数组转换(arguments&rarr;数组)** ```javascript function convert() { return [].slice.call(arguments); } convert(1, 2, 3); // [1, 2, 3] ``` 2. **ES6简化版数组转换** ```javascript const slice = Function.call.bind(Array.prototype.slice); slice(arguments); // 直接转换类数组对象 ``` ### 三、方法特性对比表 | 方法 | 改变原数组 | 返回值类型 | 时间复杂度 | |------------|------------|----------------|------------| | `slice()` | ❌ | 新数组 | O(n) | | `splice()` | ✅ | 被删除元素数组 | O(n) | | `sort()` | ✅ | 排序后数组 | O(n log n) | | `join()` | ❌ | 字符串 | O(n) | ### 四、最佳实践建议 1. **纯函数优先**:优先使用不改变原数组方法(如 `slice`/`map`/`filter`) 2. **性能敏感场景**:避免在循环中连续调用 `splice` 3. **复杂排序**:始终为 `sort()` 提供比较函数,避免字符编码排序问题[^3] 4. **大数据处理**:`forEach` 比传统 `for` 循环更易维护但性能略低[^2] --- ### 相关问题 1. `Array.prototype.map()` 和 `forEach()` 的主要区别是什么? 2. 如何实现数组合并去重操作? 3. `reduce()` 方法的高级应用场景有哪些? 4. ES6 新增的数组扩展方法有哪些优势? 5. 如何用数组方法实现浅拷贝与深拷贝? [^1]: 引用JS数组方法大全 [^2]: 引用JS数组方法(全且详细) [^3]: 引用JS数组数组方法的使用 [^4]: 引用Array.splice详解
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值