join()

Array.join(/* optional */ separator) 将数组转换为字符串,可带一个参数 separator (分隔符,默认为“,”)。

与之相反的一个方法是:String.splict() ,将字符串分隔成若干块来创建一个新的数组。

reverse()

Array.reverse(),颠倒数组元素的顺序,返回逆向的数组.注意此方法会修改原来数组元素的位置,而不是返回一个新的数组.

sort()

sort() 方法将数组中的元素排序并返回排序后的数组。sort()方法默认是按照字母表顺序进行排序的,如果想自定义排序的方式,可以传入一个比较大小的函数作为参数,如下所示:

var a = [4,2,8,6];

a.sort(function(a,b){

    return a-b;

});

console.log(a);

在此说明一下比较大小函数的使用:这个函数决定了元素的先后位置。假设第一个参数应该在在前,比较函数应该返回一个小于 0 的值,反之,则返回一个大于 0 的值。

concat()

concat() 方法创建并返回一个数组,返回的数组包含了原始数组里的元素和concat()里各个参数。注意concat()是否返回一个新的数组,而不会修改原来的数组。

slice()

slice(start,/* optional */ end) 方法返回指定数组的子数组。此方法有两个参数,第一个参数指定了开始的位置,第二个参数指定结束的位置,返回的元素索引范围[start,end)。如果不指定 end,表示返回从 start 到 数组结尾的所有元素。

splice()

splice()方法在数组里插入或删除元素。插入或删除元素时,原有元素的索引会根据需要增加或减少。splice() 方法的第一个参数指定了插入或删除的位置,第二个参数指定了删除元素的个数,之后的不定个参数为添加到数组里的元素。

var a = [1,2,8,6];

a.splice(1,3);    //删除元素

console.log(a);    //[1]

a.splice(1,0,2,3,4,5,6);    //往数组里插入元素 2,3,4,5,6

console.log(a);    //[1,2,3,4,5,6]

如果要删除数组里某个指定元素,可以这样做:
var a = [1,2,8,6];

function remove(a,x){

    for(var i=0,len=a.length;i<len;i++){

        if (a[i] == x) {

            a.splice(i,1);

            return a;

        } 

    }

    return a;

}

console.log(remove(a,2));

push() and pop()

push()方法在数组的结尾添加一个或多个元素,并返回数组新的长度。pop() 方法则相反,它删除数组里最后一个元素,减少数组的长度并并返回该删除的元素。

unshift() and shift()

unshift() 和 shift() 与 push() 和 pop() 方法类似,不同的是,unshift() 是在数组的头部插入一个或多个的元素,并返回数组新的长度。shift() 方法删除数组的第一个元素并将其返回。

以下是在 ECMAScript 5 中新定义了的 9 个操作数组方法: 其功能包括遍历、映射、过滤、检测、简化和搜索数组。

在讲解这些方法之前,有必要知道一些 ECMAScript 5 关于数组方法的介绍。首先,多数方法的第一个参数都一个函数,并且会每一个数组元素调用一次该函数。同时该函数可以使用一下三个参数:数组的元素(element),元素的索引(index),和数组本身(array)。通常我们只会用到第一个参数,而忽略其他两个参数。

遍历 .forEach(function(element,index,array))

forEach()方法从头到尾遍历一次数组元素,为每个函数调用指定函数。举例如下:

var a = [1,2,8,6];

var sum = 0;

a.forEach(function(element){

    sum += element;

});

console.log("数组求和 " + sum);

映射 .map(function(element,index,array))

map() 方法的使用方式和forEach() 方法使用类似,不同的是 map()方法会返回一个新的数组。举例如下:

var a = [1,2,8,6];

var b = a.map(function(element){

    return element + 1;

});

console.log(b); //[2,3,9,7]

过滤 .filter(function(element,index,array))

filter() 方法放回调用数组的一个子数组,其过滤作用。举例如下:

var a = [1,2,8,6];

var b = a.filter(function(element){

    return element > 3;

});

console.log(b);    //[8,6]

判定 .every((function(element,index,array)) / .some((function(element,index,array))

every 和 some 类似于离散数学的逻辑判定,返回一个布尔值。every() 函数当“所有”都返回true时,才返回 true;some()当有一个返回true时,就返回true。举例如下:判断数组是否都为正数:

var a = [1,2,8,6];

var flag = a.every(function(element){

    return element > 0;

});

console.log(flag);    //true

判断数组里是否有偶数:
var a = [1,2,8,6];

var flag = a.some(function(element){

   return element%2 === 0;

});

console.log(flag);    //true

简化 .reduce(function(v1,v2),value,element,index,array) / .reduceRight(function(v1,v2),value,element,index,array)

遍历数组,调用回调函数,将数组元素组合成一个值,reduce从索引最小值开始,reduceRight反向。

第0个参数(函数):把两个值合为一个,并返回;

第1个参数:函数(第0个参数)的初始值,可以省略。

第2个~第4个参数:数组的元素,索引和数组本身。

举例如下:

var a = [1,2,8,6];

var result = a.reduce(function(v1,v2){

    return v1+v2;

},10);

console.log(result); // 27

搜索 .indexOf(element) / lastIndexOf(element)

用于查找数组内指定元素位置,查找到第一个后返回其索引,没有查找到返回-1,indexOf从头至尾搜索,lastIndexOf反向搜索。

var a = [1,2,8,6];

var index = a.indexOf(2);

console.log(index);    //1

index = a.lastIndexOf(2);

console.log(index);    //1

Array.isArray(o)

该函数用来判断一个的对象是否是数组对象。

var a = [1,2,8,6];

console.log(Array.isArray(a));    //true

var date = new Date();

console.log(Array.isArray(date)); // false

javascript 数组的常用操作函数的更多相关文章

  1. JavaScript之数组的常用操作函数

    js对数组的操作非常频繁,但是每次用到的时候都会被搞混,都需要去查相关API,感觉这样很浪费时间.为了加深印象,所以整理一下对数组的相关操作. 常用的函数 concat() 连接两个或更多的数组,并返 ...

  2. JavaScript 数组的常用操作

    JavaScript splice 方法 splice 方法用于插入.删除或替换数组的元素.语法如下: array_object.splice(start, num, element1, elemen ...

  3. byte数据的常用操作函数[转发]

    /// <summary> /// 本类提供了对byte数据的常用操作函数 /// </summary> public class ByteUtil { ','A','B',' ...

  4. javascript中字符串常用操作整理

    javascript中字符串常用操作整理 字符串的操作在js中非常频繁,也非常重要.以往看完书之后都能记得非常清楚,但稍微隔一段时间不用,便会忘得差不多,记性不好是硬伤啊...今天就对字符串的一些常用 ...

  5. pandas_一维数组与常用操作

    # 一维数组与常用操作 import pandas as pd # 设置输出结果列对齐 pd.set_option('display.unicode.ambiguous_as_wide',True) ...

  6. Java实例 Part4:数组及其常用操作

    目录 Part4:数组及其常用操作 Example01:将二维数组的行列交换 Example02:使用选择排序法对数组进行排序 Example03:使用冒泡排序法对数组进行排序 Example04:使 ...

  7. php课程 4-17 数组键值操作函数有哪些

    php课程 4-17  数组键值操作函数有哪些 一.总结 一句话总结:多看学习视频 1.php中数组的键值操作函数有哪6个? • array_values();获取数组中的值• array_keys( ...

  8. javascript中字符串常用操作总结、JS字符串操作大全

    字符串的操作在js中非常频繁,也非常重要.以往看完书之后都能记得非常清楚,但稍微隔一段时间不用,便会忘得差不多,记性不好是硬伤啊...今天就对字符串的一些常用操作做个整理,一者加深印象,二者方便今后温 ...

  9. Javascript 数组对象常用的API

    常用的JS数组对象API ES5及以前的Api ECMAScript5为数组定义了5个迭代方法,每个方法接收两个参数, 一个是每项运行的函数,一个是运行该函数的作用域对象(可选项),传入这些方法的函数 ...

随机推荐

  1. LeetCode Day5——House Robber

    问题描述: 意思就是说:给定一个数组,寻找一种选取方法,使得在保证任何两个相邻元素不同时被选的条件下得到的数值总和最大. 1. 递归 设nums为数组首地址,numsSize为数组的大小,max[i] ...

  2. Sublime 学习记录(一) Sublime 的快捷键

    Ctrl + Shift + P : 打开命令面板 Ctrl + P : 搜索项目中的文件 Ctrl + W : 关闭当前打开的文件 Ctrl + G : 跳转到第几行 Ctrl + Shift + ...

  3. 前端自动化学习笔记(一)——Yeoman,bower,Grunt的安装

    最近看视频学习了前端自动化的一些知识,确实让我大开眼界.感觉前端越来越神器了.同时跟着视频自己也尝试运用了一些工具去构建前端项目,但是中间遇见了很多坑,磕磕绊绊的才实现了一点功能,所以打算记录一下学习 ...

  4. javascript 中 offsetWidth,clientWidth;offsetHeight,clientHeight的区别

    javascript 中 offsetWidth 是对象的可见宽度,包滚动条等边线,会随窗口的显示大小改变 clientWidth.offsetWidth.clientHeight区别IE6.0.FF ...

  5. img标签的方方面面

    <IMG>标签的方方面面 <img>标签是页面上最为重要的元素之一.很难想象一个页面上没有图片的样子,这样的页面效果将会大打折扣. 任何一个前端工程师想必对<img> ...

  6. Android之修改部分字体颜色

    #01# 方法一: TextView textView = (TextView) view.findViewById(R.id.text); SpannableString ss = new Span ...

  7. “如何稀释scroll事件”引出的问题

    背景:我在segmentfault提了个问题如何稀释onscroll事件,问题如下: 面试时问到这个问题,是这样的:    面试官问一个关于滚动到某个位置的时候出现一个顶部的导航栏,答完之后,她接着问 ...

  8. 在windows下,git webhook使用php拉取代码的学习总结

    原来上传代码到测试服务器都是用ftp,我觉得这种方式很低效,而且容易出错,比如忘记传某个修改过文件. 现在项目的代码放在了git@osc上了,想使用他webhook,每当有push的时候,git@os ...

  9. return 和 echo 的小坑

    在写项目的时候,有好几次遇到过同样的问题,控制器里面返回的json在前台无显示,利用console.log()总是显示这样的现象 数据库操作成功,却没有返回值. 原因是在控制器返回的使用使用了 ret ...

  10. 【转】MUD教程--巫师入门教程4

    我们再次复习一下clean_up()函数返回1的含义,如果clean_up()函数返回1,则MUDOS在这一次的调用时不会做其的任何举动,但到了下一次想调用的时间里,还将再次调用这个对象的clean_ ...