数组的操作方法在js中可谓是诸子百家,各种某乱的方法让人眼花缭乱,有时候就会分不清什么是自带的什么是曾今写的api了

数组的增删

1 . push() , pop()  和 shift() unshift() ;

效果:

push是最常用的了,屁股上追加 , pop()相反在屁股上扣掉一个

shift和unshift就相反是在头部开刀了 , 他们除了push()都用的不多,主要因为只能一个一个操作,而且只能在头尾

返回值

push和unshift是头尾增加后返回长度,

pop和shift返回他们删除的值

2 . splice() slice() concat()

这个方法是删除用的,但是不是删除头尾固定的一个,而是想删除哪一个就哪一个。

效果:

var arr = [ 29 , 100 , 104 , 55] ;
console.log(arr.splice(1,2))
console.log(arr)

删除俩个参数,从arr[1]开始,就是100,104被删掉了

splice接受第更多参数,就变成是插入的数组元素,就像下边的concat一样插入多个

slice接受两个参数,表示从哪到哪的被截取下来

concat() 里边可以继续写数组 如concat(6,1,2,4);

就会把数组拼起来,但依然只是放在屁股上的,只不过放连续好几个而已

返回值

splice()为删掉的值

concat()为拼合后的新数组

注意:数组有的方法不会改变原来数组,如slice concat会返回新数组,但是不会改变原来的数组

 

数组的变形

join() split()

join可以把数组变成字符串,接受参数返回字符串,数组本身不变

split接受参数,返回字符串以参数分割的数组

数组的排序

sort() reverse()

sort()接受参数为排序方法,例如sort(function(){

  return a-b

})  返回新数组

reverse()不接受参数,数组被反转。返回新数组

注意:他们都会改变数组原来的形式

ES5新方法

es5新加了一些厉害了的东西,例如find,findIndex,reduce,forEach,every,map, filter,说起来比较多,但是都不复杂,官方文档讲的十分清楚啦。

forEach(callback[,thisArg]),

map(callback[,thisArg])

forEach接收一个回调来操作每一个元素callback又接收三个参数,元素value,index,调用forEach的array [,thisArg]意思是选填的参数,代表callback中的this

没错,他就是和jquery的each一样,注意:参数顺序不同

map和forEach一样,只不过每次操作一个元素可以有个返回值,然后构成新数组

var arr = [  ,  ,  , ] ;
console.log(arr.map(function(){
return
}))

find(callback[,thisArg]),

findIndex(callback[,thisArg])

方法返回数组中满足提供的测试函数的第一个元素的值。它和forEach接收的参数一样一样的。

例如:

function isBigEnough(element) {
return element >= ;
} [, , , , ].find(isBigEnough); //
function isBigEnough(element) {
return element >= ;
} [, , , , ].findIndex(isBigEnough); //

两个区别就是一个返回第一个满足要求的元素索引,一个返回元素值

every(callback[,thisArg]),

filter(callback[,thisArg]),

some(callback[,thisArg])

这三个玩意是用来过滤的,every()some()返回true,false,前者返回是否全部通过,后者返回是否有人通过

var arr = [  ,  ,  , ] ;
console.log(arr.some(function(element){
return element >
}))

//true,表示有东西通过

var arr = [  ,  ,  , ] ;
console.log(arr.every(function(element){
return element >
}))

//false,并非全部通过

var arr = [  ,  ,  , ] ;
console.log(arr.filter(function(element){
return element >
}))

//[100, 104, 55]  //通过元素构成的新数组

reduce(callback,init)和reduceRight(callback,init)

var arr = [  ,  ,  , ] ;
console.log(arr.reduce(function(a,b){
console.log(a,b)
return a-b
},))

以init为初始值,进行init , 元素1 ,然后 元素1 ,元素2这样的方法进行遍历迭代回掉运算,

init也可没有,就直接元素1,元素2然后元素2,元素3这样遍历

reduceRight就不解释了

 include(value[,fromIndex])

数组是否包含value,是返回0,不是返回-1

这些的兼容还不错,include不兼容ie,find不兼容opera其他的都差不多

最新文章

  1. Android课程---表格布局TableLayout
  2. 答CsdnBlogger问-关于VR取代安卓的问题
  3. ADB server didn't ACK的解决方法
  4. 项目中用到的js日期函数
  5. ios开发——实用技术篇Swift篇&拍照
  6. iOS 基础 第三天(0807)
  7. API经济产业
  8. Android Jni引用第三方库
  9. js onblur 和 onkeyup 事件用法
  10. 第四十节,requests模拟浏览器请求模块初识
  11. 201521123113《Java程序设计》第8周学习总结
  12. dubbo专题」dubbo其实很简单,就是一个远程服务调用的框架(1)
  13. 炫酷:一句代码实现标题栏、导航栏滑动隐藏。ByeBurger库的使用和实现
  14. 【ELK】之Centos6.9_x64安装elasticsearch6.2.1
  15. 使用prometheus+ grafana+nginx-module-vts 模块监控openresty
  16. Deep Q-Network 学习笔记(五)—— 改进③:Prioritized Replay 算法
  17. sprint2(第三天)
  18. C# winForm调用WebService
  19. Firebird 安装多实例
  20. mount umont

热门文章

  1. bind()的模拟实现
  2. css3 随记
  3. android 中的一些小问题
  4. 02.MyBatis在DAO层开发使用的Mapper动态代理方式
  5. JWT生成token
  6. 阿里云全站加速DCDN全面支持WebSocket协议
  7. 洛谷P4027 [NOI2007]货币兑换
  8. VMware的下载安装
  9. python面向对象应用-1
  10. 08_springmvc数据回显和@ModelAttribute注解详解