Js中Array数组学习总结
第一次写博客。。。有点方。。。
小白一枚(是真的小白),自学前端,下面来说说我在学习过程中总结的一些数组操作,如果说哪有错误,请各位大神多多指出,小的虚心接受。
引用类型分为Object类型(所谓的对象),Array类型(本文谈的数组),Function类型等。
那么,数组是干啥的呢?在我看来,它是用来保存数据的。
一、声明一个数组:
1、构造函数 var colors=new Array();简写的话可以省略new,即var colors=Array();
2、数组字面量 var colors=["black","green","pink"];
二、读取和设置数组的值:
读取:colors[x];参数x为0~colors.length-1;
设置的话直接给colors[x]=进行赋值就好,这样会覆盖之前的数值哦;
三、在这里简单说说length的用法:
colors.length获取数组的长度,也可以说是数组有几项,如果说一个数组有7项,但是你写入了colors.length=2,那么就会删除后面的5项;
利用length属性也可以为数组最后添加数据:colors[colors.length]=进行赋值;
四、数组中的操作:
| 方法 | 作用 | 返回值 |
| Array.push(x,y,z) | 把xyz添加到数组末尾 | 新数组长度 |
| Array.pop() | 移除数组最后一项 | 移除的最后一项 |
| Array.shift() | 移除数组第一项 | 移除的第一项 |
| Array.unshift(a,b,c) | 在数组前端添加a,b,c | 新数组长度 |
| Array.reverse() | 反转数组 | 反转后的新数组 |
| Array.sort() | 对数组中每一项的字符串进行升序排列 | 重新排序后的数组 |
| Array.concat(a,b,c) | 连接数组 | 返回连接好的新数组 |
| Array.slice(1,n) | 截取数组,从1到n,1和n为索引值 | 返回截取的数组(在这里返回从1开始,到n之前结束) |
| Array.indexOf(a,start) | 查找a的所在的位置,从start开始 | 返回a所在的索引值,如果没有查找到则返回-1 |
| Array.lastIndexOf(a,atart) | 与indexOf相反,lastIndexOf从末尾开始查找 | 返回a所在的索引值,如果没有查找到则返回-1 |
splice()方法单拿出来说说。为什么单拿出来?因为牛逼;
1.删除。接受两个参数:要删除第一项的位置和要删除的项数;
例:splice(1,2),就是要删除数组种的2,3项;
2.插入。接受三个参数:起始位置,0,要插入的项。
例:splice(2,0,"red","green"),会在数组索引值为2的位置插入red和green。
3.替换。接受三个参数:起始位置,要删除的项数,要插入的项。
例:splice(2,1,"red","green"),删除索引值为2这一项,添加red和green。
tips:sort()用法实例:按升序排列数组
function compare(val1,val2){
if(val1<val2){
return -1;
}else if(val1>val2){
return 1;
}else{
retuen 0
}
}
var num=[0,2,9,3,1];
num.sort(compare);
alert(num);//0,1,2,3,9
五。数组中的迭代方法
1.every()和some():
查询数组中的每一项是否满足条件,如果每一项都返回true,则result返回true。
var numbers=[0,1,2,3,4];
var result=numbers.every(function(item,index,array){
return (item>2)
})
alert(result);//false
查询数组中的每一项是否满足条件,如果有一项都返回true,则result返回true。
var numbers=[0,1,2,3,4];
var result=numbers.some(function(item,index,array){
return (item>2)
})
alert(result);//true
2.filter():
该方法会返回结果为true的项组成的数组;
3.map():
var result=numbers.map(function(item,index,array){
return item*2;
})
返回数组执行完参数之后的新数组。
六。归并。
Array.reduce()
var numbers=[1,2,3,4,5];
var sum=numbers.reduce(function(prev,cur,index,array){
return prev+cur
})
alert(sum);
在上个例子中,reduce()接受四个参数,第一个参数是数组的第一项,第二个参数是数组的第二项;
第一次执行函数,prev是1,cur是2,第二次执行,prev是3(1+2的结果),cur是3。
Array.reduceRight()。和reduce类似。只不过从数组右侧开始。
华丽的分割线~叮叮叮叮~。
经过这些日子的自学,明白了一个道理。光他妈看书,看视频,真的真的,没卵用。
多敲,多总结才是王道。
在炎炎夏日,我吃着空调,吹着西瓜,美滋滋。
Js中Array数组学习总结的更多相关文章
- JS中Array数组的三大属性用法
原文:JS中Array数组的三大属性用法 Array数组主要有3大属性,它们分别是length属性.prototype属性和constructor属性. JS操作Array数组的方法及属性 本文总结了 ...
- js中Array数组基本方法
总结:push() 添加元素到数组未尾, 返回数组长度 unshift() 添加元素到数组头部, 返回数组长度 pop() 删除数组未尾元素, 返回删除元素 shift() 删除数组头部元素, 返回删 ...
- js中Array数组的属性和方法
这是我自己整理出来的一些关于Array数组的属性和方法,即查即用. 1.Array.length属性:数组的项数组,始终返回0或者更大的值. 2.instanceof操作符:value instanc ...
- js中array(数组).map
使用前 使用后 代码:
- js中的数组
上网查了一下,js中的数组包含的内容还真不少.先给出两个学习的链接: w3school链接:http://www.w3school.com.cn/js/js_obj_array.asp 博客园链接:h ...
- 多动手试试,其实List类型的变量在页面上取到的值可以直接赋值给一个js的Array数组变量
多动手试试,其实List类型的变量在页面上取到的值可以直接赋值给一个js的Array数组变量,并且数组变量可以直接取到每一个元素var array1 = '<%=yearList =>'; ...
- JS中childNodes深入学习
原文:JS中childNodes深入学习 <html xmlns="http://www.w3.org/1999/xhtml"> <head> <ti ...
- JavaScript中Array数组的方法
查找: indexOf.lastIndexOf 迭代:every.filter.forEach.map.somereduce.reduceRight 用法: /* 1 查找方法: * arr.inde ...
- String方法,js中Array方法,ES5新增Array方法,以及jQuery中Array方法
相关阅读:https://blog.csdn.net/u013185654/article/details/78498393 相关阅读:https://www.cnblogs.com/huangyin ...
随机推荐
- Varnish CentOS 6.4 x64
CentOS 6.4 x64 Varnish 安装配置 Varnish的官方网址为http://varnish-cache.org 首先下载Varnish 稳定版本3.0.3 wget ...
- MFC中PeekMessage的使用,非阻塞消息循环
在程序设计的时候经常要进行一个数据循环,比如播放音乐需要循环的向缓冲区里面写入数据,在这个时候比较通用的方法是建立一个线程做事情,但是有时候不想创建多线程就可以使用微软提供的PeekMessage方法 ...
- php中使用mysql_fetch_object向页面输出结果,总结!
public function selectResultByThird() { if ((!empty ($_REQUEST["bigname"])) && (!e ...
- codeforces #321 DIV2
A题: 链接:http://codeforces.com/contest/580/problem/A dp,最长连续不上升子序列 #include<iostream> #include&l ...
- Android点击Button按钮的四种事件监听方法总结
首先我们在activity_main.xml里面先定义一个Button空间 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 <RelativeLayout xmlns:a ...
- HCSR04超声波传感器驱动
HC_SR04是一款使用较为广泛的超声波测距模块,模块图如下 该模块具有四个引脚,分别为VCC GND TRIG ECHO,其中VCC GND为供电脚 TRIG为测距触发引脚,ECHO为测距输入引脚 ...
- SQL Server 2012 - 数据表的操作
unicode:双字节编码 variable:可变的 character:字符 T-SQL: Transact Structured Query Language unique:唯 ...
- IOS中APP开发常用的一些接口
免费的API接口: 1.聚合数据,上面有手机归属地查询等: 2.百度API store:上面有很多免费的接口,可以使用在自己的app中: 3.环信:提供一些用户交互的一些场景等,可以用来做即时通讯软件
- jQuery之事件移除
当事件执行完了,想取消事件的效果可以通过一定的办法来处理.比如bind()方法,可以通过unbind()方法来移除事件的效果. 比如下面的一个案例: <script type="tex ...
- Practice Round China New Grad Test 2014 报告
今天有Google of Greater China Test for New Grads of 2014的练习赛,主要是为了过几天的校园招聘测试做练习用的,帮助熟悉平台,题目嘛,个人觉得除了A题外, ...