js数组的各种方法
1.检测数组
①Instanceof:
if(value instanceof Array){
}
它假定只有一个全局执行环境,若网页中包含多个框架,则存在多个不同的全局执行环境,则Instanceof不能正确检测;
② Array.isArray()
无论几个全局执行环境都可以;
if(Array.isArray(value)){
}
2.转换方法
③ toString()
会返回数组的每个值拼接起来的字符串(以逗号分隔);不会影响原数组;
var colors=['red','black','blue'];
colors.toString();//red,black,blue
④ valueOf()
返回数组; 不会影响原数组;
var colors=['red','black','blue'];
colors.valueOf();// ["red", "black", "blue"]
var colors=['red','black','blue'];
alert(colors.valueOf());//red,black,blue
//因为alert()要接受字符串参数,所以其会在后台调用toString()方法,所以弹出的是字符串
⑤ toLocaleString()
与上两个相同;
⑥ join()
接收一个参数,用作字符串的分隔符,返回字符串; 不会影响原数组;
var colors=['red','black','blue'];
colors.join('||');// red||black||blue
3.栈方法
⑦ push()
将接受到的参数添加到数组末尾,返回字符串的长度; 影响原数组;
var colors=['red','black','blue'];
colors.push('green','pink'); //5
⑧ pop()
移除数组末尾的最后一项,返回移除的项;影响原数组;
var colors=['red','black','blue'];
colors.pop(); //blue
pop()和push()结合使用,可以实现队列方法;
4.队列方法
⑨ shift()
移除数组的第一项,并返回该项;影响原数组;
1 var colors=['red','black','blue'];
2 colors.shift(); //red
⑩ push()
shift()和push()结合使用,可以实现队列方法;
11. unshift()
将接受到的参数添加到数组前端,返回字符串的长度;
var colors=['red','black','blue'];
colors.unshift("green"); //4
5.重排序方法
12. reverse()
反转数组项顺序,改变数组本身,返回数组本身;;
var number=[1,2,3,5,4];
value=number.reverse(); //[4, 5, 3, 2, 1]
console.log(value) // [4, 5, 3, 2, 1]
console.log(number) // [4, 5, 3, 2, 1]
13.sort()
改变数组本身的值,返回数组本身;
var number=[1,2,3,5,4];
value=number.sort(compare); //[1,2,3,4,5 ]
function compare(a,b){
return a-b;
}
console.log(number); //[1, 2, 3, 4, 5]
6.操作方法
14. concat()
连接几个数组,返回新构建的数组;不会影响数组本身;
var colors=['red','black','blue'],col=["pink","green"],colo=['brown']; colors.concat(col,colo,'yellow');
//["red", "black", "blue", "pink", "green", "brown", "yellow"]
15. slice()
接受1或2个参数,即返回项的起始和结束位置;不会影响数组本身;
var colors=['red','black','blue'];
colors.slice(1,2); //["black"]
colors.slice(1); // ["black", "blue"]
16. splice()
原数组随之改变;返回删除的项(数组形式),若未删除则返回空数组;
输入2个参数: 起始位置和要删除的数组长度;
删除:
var colors=['red','black','blue'];
colors.splice(1,2); //["black", "blue"]
console.log(colors); //["red"]
输入3个参数:
插入: 起始位置,要删除的数组长度(0),要插入的项;
var colors=['red','black','blue'];
colors.splice(1,0,'green'); //[]
console.log(colors); //["red", "green", "black", "blue"]
替换: 起始位置,要删除的数组长度,要插入的项;
var colors=['red','black','blue'];
colors.splice(1,1,'green','purple'); //["black"]
console.log(colors); //["red", "green", "purple", "blue"]
7.位置方法
17. indexOf() :从开头往后查找
输入:要查找的项和(查找起点位置的索引){默认为0};返回要查找的项在数组中的位置;
var colors=['red','black','blue','black','green'];
colors.indexOf('black'); //1
colors.indexOf('black',2); //3
18.lastIndexOf() :从末尾往前查找
输入:要查找的项和(查找起点位置的索引){默认为length-1};返回要查找的项在数组中的位置;
var colors=['red','black','blue','black','green'];
colors.lastIndexOf('black'); //3
colors.lastIndexOf('black',2); //1
8.迭代方法
every(),filter()…
http://www.cnblogs.com/sunmarvell/p/8674935.html
9.归并方法
24 reduce()
迭代数组的所有项,构建一个最终返回值; 不改变原数组的值
从第一项开始,逐个遍历到最后;
var number=[1,2,3,5,4];
value=number.reduce(compare); //-13
function compare(a,b){
return a-b;
}
console.log(number); //[1,2,3,5,4]
25 reduceRight()
迭代数组的所有项,构建一个最终返回值; 不改变原数组的值
从最后一项开始,逐个遍历到第一项;
var number=[1,2,3,5,4];
value=number.reduceRight(compare); //-7
function compare(a,b){
return a-b;
}
console.log(number); //[1,2,3,5,4]
js数组的各种方法的更多相关文章
- js数组去重的方法(转)
JS数组去重的几种常见方法 一.简单的去重方法 // 最简单数组去重法 /* * 新建一新数组,遍历传入数组,值不在新数组就push进该新数组中 * IE8以下不支持数组的indexOf方法 * */ ...
- js数组高阶方法reduce经典用法代码分享
以下是个人在工作中收藏总结的一些关于javascript数组方法reduce的相关代码片段,后续遇到其他使用这个函数的场景,将会陆续添加,这里作为备忘. javascript数组那么多方法,为什么我要 ...
- JS —— 数组与字符串方法
数组 1. 基本方法 1)Array.prototype.unshift(item1,item2,item3...) 描述: 在数组的前面添加元素,一次可以传入多个参数. 注意:元素会根据当前传入的 ...
- JS 数组常用的方法
数组常用的方法: x.toString()方法:任何对象都有toString方法. 将任何对象转为字符串. 一般不主动调用,系统在需要时自动调用 x.valueOf()方法:同toStr ...
- js数组的forEach方法能不能修改数组的值
如果要使用数组的forEach()方法对其改值时,需要直接通过arr[i]这种方式来更改. 请看下面代码: // 数组改值 let arr = [1,3,5,7,9]; arr.forEach(fun ...
- Js 数组的各种方法及操作
一.数组去重 var arr = [0,1,20,3,0,45,6,0]; Array.prototype.unrepeat = function(){ var array = []; for(var ...
- js数组之迭代方法
ES5为数组对象定义了5个迭代方法(即递归,简单的说就是自己可以调用自己). 每个方法接收两个参数:要在每一项上运行的函数(接收3个参数:数组项的值,该项在数组中的位置,数组对象本身)和(可选的) ...
- js数组声明+split()方法
split()方法:var words = sentence.split(' '): "hello".split("", 3) //可返回 ["h&q ...
- js 数组中的方法
<!DOCTYPE html><html><head> <title>数组的方法</title> <meta charset=&quo ...
- 两种js数组去重的方法
方法一: 新建一个数组,遍历原数组,在新数组内用IndexOf查找原数组内的每一项,如果没有找到,则添加到其中 代码如下: function arrayNew(arrs ){ var newArray ...
随机推荐
- 纯css3实现按钮的 hover 和 active 时颜色的明暗变化效果
效果:在任意HTML标签上增加样式类 f-color-control 就可以为此元素增加hover和avtive时颜色的变化; 代码如下: <!DOCTYPE html> <html ...
- 纤程(FIBER)
Indy 10 还包含对纤程的支持.纤程是什么?简单来说,它也是 一个“线程”,但是它是由代码控制的,而不是由操作系统控制的.实际上,可以认为线程 是一个高级纤程.纤程和 Unix 用户线程(Unix ...
- JAVA —— String is immutable. What exactly is the meaning? [duplicate]
question: I wrote the following code on immutable Strings. public class ImmutableStrings { public st ...
- IntelliJ IDEA在行尾增加分号
IntelliJ IDEA在行尾增加分号 Ctrl+Shift+Enter - 本身的含义是自动完成,如果需要的话,会在行尾添加分号:
- PowerDesinger15设置字体大小
使用PowerDesigner时,它默认table的字体大小颜色等很难看: 假设通过 Symbol ---> Format进行设置.仅仅能对选中的最改动,新建的Table无效. 能够通过例如以下 ...
- 杭电 3555 Bomb
Bomb Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others) Total Subm ...
- java之Map源代码浅析
Map是键值对.也是经常使用的数据结构. Map接口定义了map的基本行为.包含最核心的get和put操作,此接口的定义的方法见下图: JDK中有不同的的map实现,分别适用于不同的应用场景.如线程安 ...
- Codeforces Round #320 (Div. 2) [Bayan Thanks-Round] C C Problem about Polyline 数学
C. A Problem about Polyline ...
- 【bzoj1150】[CTSC2007]数据备份Backup
将k对点两两相连,求最小长度 易证得,最优方案中,相连的办公楼一定是取相邻的比取不相邻的要更优 然后就可以用贪心来做这道题了.. 将初始所有的线段放进堆里 每次取最短的线段进行连接,且ans+=a[i ...
- HTML DOM createTextNode() 方法
实例 创建一个文本节点: var btn=document.createTextNode("Hello World"); 输出结果: Hello World 尝试一下 » HTML ...