js数组学习整理
原文地址:js数组学习整理
常用的js数组操作方法及原理
1、声明数组的方式
var colors = new Array();//空的数组
var colors = new Array(3); //长度为3
var colors = new Array('red','blue');//初始化
其中,在声明数组的时候,去掉new操作符,也可以。
还有一种初始化数组的方式,使用数组字面量表示法 。
数组字面量由一对包含数组项的方括号表示,多个数组项之间用逗号隔开。
var colors = [ 'red', 'blue']; var colors = [];
2、数组的length , 不是只读的,可以用它来增删数组。
var color = ['red', 'blue', 'green']; color.length = 2; alert(color[2]); // undefined,说明这个值已经不存在了
增加数组项
var colors = ['red','blue']; colors[colors.length] = 'green';
3、检测数组
如果只有一个全局的环境,可以用
if( value instanceof Array ){ }
但如果一个网页中有框架,就会有多个全局环境,那么Array构造函数就会有多个,此时用
Array.isArray(value);//IE9+
4、转换方法(将数组转化为字符串)
所有对象都有toLocalString()、toString()、这2个方法返回以逗号分隔的字符串,它们的原理分别是循环数组,将数组的每一项分别使用toLocalString()、toString()方法后,拼接成字符串。
join()方法是可以指定分隔的符号来返回字符串。如果在join()中不指定分隔符,默认为逗号。
如果数组中的一项值是null,或者undefined,使用join(),toLocalString()、toString()方法返回的是以空字符串表示该项。
valueOf()返回的还是数组
5、向数组中添加或取出值(栈方法,队列方法)
var colors = [];
colors.push('red'); // 返回数组长度 1
colors.pop(); //返回数组最后一项red
这2个方法都是像栈一样的形式,直接操作最后的元素,也就是后来的元素。
还有2种方法像队列一样的形式操作数组,shift,unshift
var colors = ['red', 'blue'];
colors.shift(); // 返回的是数组第一项red
colors.unshift('green'); // 返回数组长度3
取值操作pop(),shift(),会返回一个值
push(),unshift(),会返回添加以后的数组长度。
6、排序方法
var color = [1,2,3,4]; color.reverse(); // 反转数组 4,3,2,1 color.sort(); //默认是升序排列 1,2,3,4 //但如果colors = [1, 2, 3, 15];使用sort时会返回 1, 15, 2 ,3
sort();方法会对数组的每一项进行toString()。所以最后得到的数组每一项字符串。所以会出现那样的结果。
但sort()接收一个比较方法的函数作为参数,那我们可以自定义一个compare函数
//自定义升序
function compare(v1, v2){
if(v1 < v2)
return -1;
else if(v1 > v2)
return 1;
else
return 0;
}
var values = [0, 1, 3, 15]
values.sort(compare); //返回1,2,3,15
7、操作方法(concat,slice,splice)
这里concat和slice方法都不会直接操作原数组,而是返回一个新的数组,原数组不会改变。
var colors = ['red', 'blue']; var a = ['green'];
alert(colors.concat(a));//['red', 'blue', 'green']
alert(colors); //['red', 'blue']
slice很像python切割字符串。
var colors = ['red', 'blue', 'green']; colors.slice(1);//返回[blue,green] colors.slice(1,3);//返回['blue']
slice()如果传入一个负值,则用数组长度加上这个值,对应的就是等价的值
//如果数组长度为5 slice(-2, -1); 与 slice(3, 4);相等
splice(‘起始位置’, ‘删除数量'[, ‘代替值’]);它是直接操作原数组,以数组形式返回被操作的元素
var colors = ['red', 'green', 'blue']; colors.splice(1, 1); // 返回[‘green’] ,而原数组为[red, blue] colors.splice(1, 0, 'yellow'); //返回一个空数组 ,而原数组为[red,yellow,green,blue]
8、位置方法(indexOf, lastIndexOf)
indexOf(‘要查找的项'[, ‘查找起点的索引’])返回数组值的索引,从第一个值开始查找、 lastIndexOf则相反。
var num = [1,2,3,4,5,6]; num.indexOf(3); //返回2 num.indexOf(3, 3); //返回-1,表示该值不存在
【全文完】
js数组学习整理的更多相关文章
- JS数组学习笔记
原文:JS数组学习笔记 最近在备课数组,发现很多ES5的方法平时很少用到.细节比较多,自己做了大量例子和整理,希望对大家了解JavaScript中的Array有所帮助. 概念 数组是值的有序集合.每个 ...
- JS数组方法整理(附使用示例)
整理目前所用过的数组方法,学习了新增的es6方法. 1.arr.push() 从后面添加元素,返回值为添加完后的数组的长度 let arr = [1,2, is 8.3,4,5] console.lo ...
- js数组基础整理
首页: 主要整理了一下数组中常用的一些基础知识,代码都是自己手敲,有不对的地方希望能指出,目前只有4篇,后续会不断的增加这一板块. 由于少于100字不能发所以把一些最基本的创建数组也写上. // 创建 ...
- js数组常用方法整理
学疏才浅,若有不对的地方,希望大家可以帮忙指正出来. 1. Array.push(),向数组的末尾添加一个或多个元素,并返回新的数组长度.原数组改变. 2. Array.pop(),删除并返回数组的最 ...
- JS 数组 学习笔记
什么是数组 数组(array)是按次序排列的一组值.每个值的位置都有编号(从0开始),整个数组用方括号表示.本质上数组属于一种特殊的,由Array构造出来的对象,typeof运算符返回数组的类型是 o ...
- !!对python列表学习整理列表及数组详细介绍
1.Python的数组分三种类型:(详细见 http://blog.sina.com.cn/s/blog_6b783cbd0100q2ba.html) (1) list 普通的链表,初始化后可以通过特 ...
- [学习笔记]JS 数组Array push相关问题
前言: 今天用写了一个二维数组,都赋值为零,然后更新其中一个值,结果和预期是不一样,会整列的相同位置都是同一个值. 1.用Chrome的控制台样例如下: arrs[2][2] =1的赋值,竟然是三个数 ...
- js 数组常用的操作函数整理
平时多做企业应用开发,抱着实用为主,对前端技术理解得比较肤浅,下面就是肤浅地对 js 数组的属性和方法及对它操作的 jquery 方法做些记录: js 数组是 js 内建的一个非常强大数据类型,由于 ...
- JS正则表达式大全(整理详细且实用)
JS正则表达式大全(整理详细且实用).需要的朋友可以过来参考下,希望对大家有所帮助!! 正则表达式中的特殊字符 字符 含意 \ 做为转意,即通常在"\"后面的字符不按原来意义解释, ...
随机推荐
- Sql Server系列:分区表操作
1. 分区表简介 分区表在逻辑上是一个表,而物理上是多个表.从用户角度来看,分区表和普通表是一样的.使用分区表的主要目的是为改善大型表以及具有多个访问模式的表的可伸缩性和可管理性. 分区表是把数据按设 ...
- Apache执行Python脚本
由于经常需要到服务器上执行些命令,有些命令懒得敲,就准备写点脚本直接浏览器调用就好了,比如这样: 因为线上有现成的Apache,就直接放它里面了,当然访问安全要设置,我似乎别的随笔里写了安全问题,这里 ...
- 通过一个demo了解Redux
TodoList小demo 效果展示 项目地址 (单向)数据流 数据流是我们的行为与响应的抽象:使用数据流能帮我们明确了行为对应的响应,这和react的状态可预测的思想是不谋而合的. 常见的数据流框架 ...
- 无法向会话状态服务器发出会话状态请求。请确保 ASP.NET State Service (ASP.NET 状态服务)已启动,并且客户端端口与服务器端口相同。如果服务器位于远程计算机上,请检查。。。
异常处理汇总-服 务 器 http://www.cnblogs.com/dunitian/p/4522983.html 无法向会话状态服务器发出会话状态请求.请确保 ASP.NET State Ser ...
- 【C#代码实战】群蚁算法理论与实践全攻略——旅行商等路径优化问题的新方法
若干年前读研的时候,学院有一个教授,专门做群蚁算法的,很厉害,偶尔了解了一点点.感觉也是生物智能的一个体现,和遗传算法.神经网络有异曲同工之妙.只不过当时没有实际需求学习,所以没去研究.最近有一个这样 ...
- SDWebImage源码解读之SDWebImageCache(下)
第六篇 前言 我们在SDWebImageCache(上)中了解了这个缓存类大概的功能是什么?那么接下来就要看看这些功能是如何实现的? 再次强调,不管是图片的缓存还是其他各种不同形式的缓存,在原理上都极 ...
- SharpMap简析
1.背景 因为项目需求,需要基于开源项目来对SHP进行相关操作.涉及到的主要功能就是加载SHP读取其中的属性信息和几何信息.于是选择了Sharpmap来进行,在使用中对其相关功能做了初步了解,做个总结 ...
- 打破陈规抓痛点,H3 BPM10.0挑战不可能
高效益意味着相似的运营活动比竞争对手做得更好,而战略定位则意味着企业在运营活动中有区别于竞争对手的实施方式,即差异化竞争.在新经济体下,面对社会的变革.市场的竞争环境.不断攀升的成本压力,几乎没有企业 ...
- mysql删除重复记录语句的方法
例如: id name value 1 a pp 2 a pp 3 b iii 4 b pp 5 b pp 6 c pp 7 c pp 8 c iii id是主键 要求得到这样的结果 id name ...
- NYOJ 998
这道题是欧拉函数的使用,这里简要介绍下欧拉函数. 欧拉函数定义为:对于正整数n,欧拉函数是指不超过n且与n互质的正整数的个数. 欧拉函数的性质:1.设n = p1a1p2a2p3a3p4a4...pk ...