JavaScript中数组的各种操作方法
【监测数组】
- 使用instanceof操作符,进行检测
ar arr = [1,2,3];
// arr = '非非';
if(arr instanceof Array){
console.log('是数组');
}else{
console.log('不是数组');
}备注:ES3中使用instanceof操作符的前提是,当前页面只有一个执行环境,当网页中存在多个框架的时候,这种检测方式出现问题;为了解决这个问题,ES5提出了第二种方法
- Array.inArray()方法
var arr = [1,2,3];
// arr = '非非';
if(Array.isArray(arr)){
console.log('是数组');
}else{
console.log('不是数组');
}备注:IE8是不支持这种检测的,当然了对于其兼容性还是可以实现的;不过现在对于IE8早已无人问津
【数组转换字符串】
- toString()方法
var arr = [
[1,2,3],
['非非','咖啡'],
[8,9]
];
console.log(arr.toString());//1,2,3,非非,咖啡,8,9 - join()方法
var arr = [
[1,2,3],
['非非','咖啡'],
[8,9]
];
console.log(arr.join(','));//1,2,3,非非,咖啡,8,9
console.log(arr.join('||'));//1,2,3||非非,咖啡||8,9
【数组排序】
- reverse()反转数组项的顺序
var arr = [1,2,3,4];
var arr1 = ['非非','琪琪','艾艾'];
console.log(arr.reverse());//[4, 3, 2, 1]
console.log(arr1.reverse());//["艾艾", "琪琪", "非非"] - sort()
- 默认情况下,按升序排列数组项(默认比较的是每一项的字符串形式,toString())
var arr = [1,2,3,4];
var arr1 = ['非非','琪琪','艾艾'];
var arr2 = [1,2,3,4,11];
console.log(arr.sort());//[1, 2, 3, 4]
console.log(arr1.sort());// ["琪琪", "艾艾", "非非"]
console.log(arr2.sort());//[1, 11, 2, 3, 4] - sort()接受一个比较函数的参数
function compare(value1, value2){
if(value1 < value2){
return -1;
}else if(value1 > value2){
return 1;
}else{
return 0;
}
}
// 简化比较函数
function compare(value1, value2){
return value1 - value2;
}
var arr = [1,2,3,4,11];
console.log(arr.sort(compare));//[1, 2, 3, 4, 11]
- 默认情况下,按升序排列数组项(默认比较的是每一项的字符串形式,toString())
【数组插入】
- push()从后面插入新项
var arr = [1,2,3,4];
arr.push(8,9)
console.log(arr);//[1, 2, 3, 4, 8, 9] - unshift()从前面插入新项
var arr = [1,2,3,4];
arr.unshift(8,9)
console.log(arr);//[8, 9, 1, 2, 3, 4] - splice()-插入
var arr = [1,2,3,4,5];
arr.splice(3,0,'非非')
console.log(arr);//[1, 2, 3, "非非", 4, 5]
【数组删除】
- pop()删除数组最后一项
var arr = [1,2,3,4];
arr.pop()
console.log(arr);//[1, 2, 3] - shift()删除数组第一项
var arr = [1,2,3,4];
arr.shift()
console.log(arr);//[2, 3, 4] - splice()-删除
var arr = [1,2,3,4,5,6,7,8,9];
arr.splice(0,3)
console.log(arr);//[4, 5, 6, 7, 8, 9]
【数组替换】
splice()-替换
var arr = [1,2,3,4,5];
arr.splice(2,1,'非非','琪琪')
console.log(arr);//[1, 2, "非非", "琪琪", 4, 5]
【数组位置查找】
var arr = [1,2,'非非',3,4,5,'非非','琪琪'];
console.log(arr.indexOf('非非'));//
console.log(arr.lastIndexOf('非非'));//
【数组合并】
concat()
var arr = [1,2,3,4,11];
var arr1 = ['非非','琪琪'];
console.log(arr.concat(arr1));// [1, 2, 3, 4, 11, "非非", "琪琪"]
console.log(arr1.concat(arr));//["非非", "琪琪", 1, 2, 3, 4, 11]
【数组截取】
slice(),接收一个或两个参数,第一个参数是数组起始位置(结果包括起始位置项),第二个参数是结束位置(结果不包括结束项);支持负数,用长度length减去负数,就是当前项的位置
var arr = [1,2,3,4,5,6,7,8,9];
console.log(arr.slice(1));//[2, 3, 4, 5, 6, 7, 8, 9]
console.log(arr.slice(1,5));//[2, 3, 4, 5]
console.log(arr.slice(-3));//[7, 8, 9]
console.log(arr.slice(-4,-1));//[6, 7, 8]
【迭代方法】
- every()对数组中的每一项运行给定函数,如果该函数对每一项都返回true,则返回true
var arr = [1,2,3,4,5,6,7,8];
var everyMethods = arr.every(function(item, index, array){
return item > 0;
});
console.log(everyMethods);//true - filter()对数组中的每一项运行给定函数,返回该函数会返回true的项组成的数组
var arr = [1,2,3,4,5,6,7,8];
var filterMethods = arr.filter(function(item, index, array){
return item > 6;
});
console.log(filterMethods);//[7, 8] - forEach()对数组中的每一项运行给定函数。这个方法没有返回值(与使用for循环迭代数组一样)
var arr = [1,2,3,4,5,6,7,8];
var forEachMethods = arr.forEach(function(item, index, array){
console.log('item=>'+item);
console.log('index=>'+index);
console.log('array=>'+array);
});
console.log(forEachMethods);
// item=>1
// array.html:24 index=>0
// array.html:25 array=>1,2,3,4,5,6,7,8
// array.html:23 item=>2
// array.html:24 index=>1
// array.html:25 array=>1,2,3,4,5,6,7,8
// array.html:23 item=>3
// array.html:24 index=>2
// array.html:25 array=>1,2,3,4,5,6,7,8
// array.html:23 item=>4
// array.html:24 index=>3
// array.html:25 array=>1,2,3,4,5,6,7,8
// array.html:23 item=>5
// array.html:24 index=>4
// array.html:25 array=>1,2,3,4,5,6,7,8
// array.html:23 item=>6
// array.html:24 index=>5
// array.html:25 array=>1,2,3,4,5,6,7,8
// array.html:23 item=>7
// array.html:24 index=>6
// array.html:25 array=>1,2,3,4,5,6,7,8
// array.html:23 item=>8
// array.html:24 index=>7
// array.html:25 array=>1,2,3,4,5,6,7,8 - map()对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组
var arr = [1,2,3,4,5,6,7,8];
var mapMethods = arr.map(function(item, index, array){
return item*2;
});
console.log(mapMethods);//[2, 4, 6, 8, 10, 12, 14, 16] - some()对数组中的每一项运行给定函数,如果该函数对任一项返回true,则返回true
var arr = [1,2,3,4,5,6,7,8];
var someMethods = arr.some(function(item, index, array){
return item > 6;
});
console.log(someMethods);//true
【归并方法】
reduce()方法 and reduceRight()方法
这两个方法,目前所知的使用方法比较简单,在实际的开发中,完全可以采用其他方式达到这种效果,就先养着吧,万一那一天我明白了,再补上
JavaScript中数组的各种操作方法的更多相关文章
- JavaScript中数组操作常用方法
JavaScript中数组操作常用方法 1.检测数组 1)检测对象是否为数组,使用instanceof 操作符 if(value instanceof Array) { //对数组执行某些操作 } 2 ...
- javascript中数组Array的方法
一.常用方法(push,pop,unshift,shift,join)push pop栈方法,后进先出var a =[1,2,3];console.log(a.push(40)); //4 返回数组的 ...
- Javascript中数组
Javascript中数组 1.什么是数组 所谓的数组就是一组数据的集合,在内存中表现为一段连续的内存地址(保存在堆内存) 2.创建数组的含义 创建数组的目的:就是为了保存更多的数据 3.数组的定义 ...
- javascript中数组常用方法总结
原文:javascript中数组常用方法总结 在javascript的基础编程中,数组是我们最常遇到的,那么数组的一些常用方法也是我们必须要掌握的,下面我们总结一下数组中常用的方法. toString ...
- JavaScript中数组Array方法详解
ECMAScript 3在Array.prototype中定义了一些很有用的操作数组的函数,这意味着这些函数作为任何数组的方法都是可用的. 1.Array.join()方法 Array.join()方 ...
- javascript中数组的常用算法深入分析
Array数组是Javascript构成的一个重要的部分,它可以用来存储字符串.对象.函数.Number,它是非常强大的.因此深入了解Array是前端必修的功课.本文将给大家详细介绍了javascri ...
- javascript中数组化的一般见解
javascript中数组化的一般见解,数组化浏览器中存在许多类数组对象,往往对类数组操作比较麻烦,没有数组那些非常方便的方法,在这种情况下,就有了数组化方法. 数组化的一般方法 1.第一种也是我们最 ...
- 总结Javascript中数组各种去重的方法
相信大家都知道网上关于Javascript中数组去重的方法很多,这篇文章给大家总结Javascript中数组各种去重的方法,相信本文对大家学习和使用Javascript具有一定的参考借鉴价值,有需要的 ...
- JavaScript中数组常用方法的总结
JavaScript中数组Array常用的方法总结 标签(空格分隔): JavaScript ECMAScript数组给我们提供了许多常用的方法,便于我们对数组进行操作,下面,就来总结一下这些方法. ...
随机推荐
- mysql 操作时间戳
1.将long显示成时间 SELECT FROM_UNIXTIME(1249488000, '%Y%m%d' ) 2.日期格式化成时间戳 SELECT UNIX_TIMESTAMP('2016-05- ...
- Photon3Unity3D.dll 解析三——OperationRequest、OperationResponse
OperationRequest 代表Operation操作的Request,包含Code和Parameters OperationCode Byte类型的值,代表操作,由LiteOpCode定义了 ...
- LightOJ 1024 Eid(高精度乘法+求n个数最小公约数)
题目链接:https://vjudge.net/contest/28079#problem/T 题目大意:给你n个数求这些数的最小公倍数(约数). 解题思路:还太菜了,看了别人的题解才会写,转自这里, ...
- Logistic回归与梯度上升算法
原创作品出处 原始出处 .作者信息和本声明.否则将追究法律责任.http://sbp810050504.blog.51cto.com/2799422/1608064 Logistic回归与梯度上升算法 ...
- Fiddler Web Session 列表(1)
Web Session 列表 位置: Web Session 列表 位于Fiddler界面的左侧 ,是Fiddler所抓取到的所有Session会话的列表集合. Web Session 列表 栏名词解 ...
- python基础(8)--迭代器、生成器、装饰器
1.迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外,迭代器的一大优 ...
- 安装requests
requests包让Python程序能够轻松地向网站请求信息以及检查返回的响应.要安装requests,请执行类似于下面的命令: $ pip3 install --user requests http ...
- TCP和UDP发送数据包的大小问题
用UDP协议发送时,用sendto函数最大能发送数据的长度为:65535-20-8=65507字节,其中20字节为IP包头长度,8字节为UDP包头长度.用sendto函数发送数据时,如果指的的数据长度 ...
- 湖南大学ACM程序设计新生杯大赛(同步赛)J - Piglet treasure hunt Series 2
题目描述 Once there was a pig, which was very fond of treasure hunting. One day, when it woke up, it fou ...
- WP SyntaxHighlighter 初探
继上篇文章发布后,我随即去网上找了下博客园.CSDN他们用的高亮工具,果然都是用的别人的,SyntaxHighlighter.去官网上看了下,很强大,包含各种经典配色以及多语言.要想在wordpres ...