JavaScript数组的基本操作
数组的创建方式:
方式一:构造函数构建数组
var arr = new Array ( ); 如果传入的参数为一个数字,代表数组的长度,不包含内容
// 可以传入字符串和数字,用逗号隔开,作为数组中的内容。
方法二:字面量方法创建数组 (一般采用该方法)
var arr = [ ]; // 可以直接写入内容。用逗号隔开
数组的基本操作方法:
目录:
- push
- pop
- unshift
- shiift
- concat
- join
- splice
- slice
- indexOf
- lastIndexOf
push()方法
var len = arr.push( )
在数组尾部添加一个或多个新元素,并且返回数组的新长度。
原生JS重构 push方法

1 function push(arr) {
2
3 for (i = 1; i < arguments.length; i++) {
4
5 arr[arr.length] = arguments[i]; //数组的尾部添加传入进来的参数
6
7 }
8
9 return arr.length; //返回数组的长度
10
11 }
12
13 var num = push(arr, 7, 8, 9)
14
15 console.log(arr, i)

pop()方法
var itme = arr.pop( )
删除数组尾部的一个或者多个元素,并且返回被删除的这个元素
原生JS重构 pop方法

1 function pop(arr) {
2
3 var num = arr[arr.length - 1]; //保存数组最后一个元素
4
5 arr.length--; //删除最后一个元素
6
7 return num //返回删除的元素
8
9 }
10
11 pop(arr)

unshuift( ) 方法
//将一个或者多个新元素添加在数组的最前面,返回数组的新长度
var len = arr.unshift( )
原生JS重构 unshift方法

1 function unshift(arr) {
2
3 var len = arguments.length - 1; //定义需要添加元素的长度,
4
5 for (var i = arr.length - 1; i >= 0; i--) { //使数组整体向后移动len个单位
6
7 arr[i + len] = arr[i];
8
9 // console.log(arr)
10
11 }
12
13 for (var j = 1; j < arguments.length; j++) { // 把传入的参数按顺序放入数组的前头
14
15 arr[j - 1] = arguments[j]
16
17 console.log(arr)
18
19 }
20
21 return arr.length //返回新数组的长度
22
23 }
24
25 unshift(arr, 9, 8, 7)
26
27

shift( ) 方法
// 删除数组的第一个元素,并且返回该元素。
var itme =arr.shift( )
原生JS重构 shift方法:

1 function shift(arr) {
2
3 var itme = arr[0]; //获取第一个元素
4
5 // console.log(itme)
6
7 for (i = 0; i < arr.length; i++) { //把数组整体向前移动一个长度
8
9 arr[i] = arr[i + 1]
10
11 console.log(arr)
12
13 }
14
15 return itme //返回数组的第一个元素
16
17 }
18
19 console.log(shift(arr))

concat ()方法
var arr1 = arr.concat ( 10,11,12)
var arr2 =arr.concat ( arr1 )
//给原数组添加新元素或连接多个数组,复制给一个新数组
原生JS重构 concat方法:

1 function concat(arr) {
2
3 var array = []; //定义一个空数组 用来复制新数组
4
5 var num = 0; //新数组的下标
6
7 for (var i = 0; i < arr.length; i++, num++) { //把第一个数组复制到新数组中
8
9 array[num] = arr[i]
10
11 }
12
13 for (var j = 1; j < arguments.length; j++, num++) { //把参数复制到新数组中
14
15 if (arguments[j].constructor === Array) { //判断参数是否是数组类型
16
17 for (var m = 0; m < arguments[j].length; m++, num++) { //遍历参数数组,添加到新数组中
18
19 array[num] = arguments[j][m]
20
21 }
22
23 num-- // 由于上面两次循环 新数组下标添加了2次, 所以在这减少一次
24
25 } else { //参数不是数组类型,把参数添加到新数组中
26
27 array[num] = arguments[j]
28
29 }
30
31 }
32
33 return array //返回新数组
34
35 }

join ()方法
var str = arr.join( )
join() 方法用于把数组中的所有元素放入一个字符串。
元素是通过指定的分隔符进行分隔的。若没有填入参数,默认用逗号隔开
splice ()方法
arr.splice (从什么位置开始,删除多少个元素,添加的元素…… )
//给数组中添加,删除,替换一个或者多个元素,返回被删除元素组成的数组
var arr1 =arr.splice( ) //创建一个空数组arr1
var arr1 =arr.splice( 0 ) 删除arr所有元素 ,将所有元素传递给arr1、
var arr1 =arr.splice( -1)传入的参数是负数的时候,表示倒数第几位开始。
var arr1 =arr.splice( 2,0,12,14)表示从第二位开始,不删除元素,插入12和14
//(正数是向后插入元素, 负数是向前插入元素)
slice()方法
功能:截取指定位置的数组,并且返回截取的数组,不会改变原数组
参数:slice(startIndex, endIndex)
注意:可从已有的数组中返回选定的元素。该方法接收两个参数slice(start,end),省略表示到最后一位;
start和end都可以为负数,负数时表示从最后一位开始算起,如-1表示最后一位。
IndexOf()方法
功能:根据指定的数据,从前往后,查询在数组中出现的位置,如果不存在指定的数据,返回-1,找到了指定的数据返回该数据的索引
参数:indexOf(value, start);value为要查询的数据;start为可选,表示开始查询的位置,当start为负数时,从数组的尾部向前数;如果查询不到value的存在,则方法返回-1
注意:如果找到该数据,立即返回该数据的索引,不再往后继续查找
lastIndexOf( )方法
功能:根据指定的数据,从后往前,查询在数组中出现的位置,如果不存在指定的数据,返回-1,找到了指定的数据返回该数据的索引
参数:indexOf(value, start);value为要查询的数据;start为可选,表示开始查询的位置,当start为负数时,从数组的尾部向前数;如果查询不到value的存在,则方法返回-1
JavaScript数组的基本操作的更多相关文章
- JavaScript 数组基本操作
简介 数组操作无论是在JavaScript中还是在其他语言中都是很常见.经常会用到的,现在我把JavaScript 数组基本操作整理一下,供大家参考学习.里边包含我自己的见解以及案例,希望能够帮助大家 ...
- 舌尖上的javascript数组和字符串基本操作
Javascript数组基本操作 Javascript中的数组是一种特殊的对象,用来表示偏移量的索引是该对象的属性,索引可能是整数,然而这些数字索引在内部被转换为字符串类型,这是因为javascrip ...
- Javascript中数组的基本操作
删除数组指定的某个元素 via首先可以给JS的数组对象定义一个函数,用于查找指定的元素在数组中的位置,即索引,代码为: Array.prototype.indexOf = function(val) ...
- javascript数组浅谈1
最近心血来潮要开始玩博客了,刚好也在看数组这块内容,第一篇就只好拿数组开刀了,自己总结的,有什么不对的地方还请批评指正,还有什么没写到的方面也可以提出来我进行完善,谢谢~~ 首先,大概说说数组的基本用 ...
- Javascript数组操作
使用JS也算有段时日,然对于数组的使用,总局限于很初级水平,且每每使用总要查下API,或者写个小Demo测试下才算放心,一来二去,浪费不少时间:思虑下,堪能如此继续之?当狠心深学下方是正道. 原文链接 ...
- Javascript数组操作(转)
1.数组的创建 var arrayObj = new Array(); //创建一个数组 var arrayObj = new Array([size]); //创建一个数组并指定长度,注意不是上限, ...
- JavaScript 数组
JavaScript 数组 简介:数组是值的有序集合,JavaScript在同一个数组中可以存放多种类型的元素,而且是长度也是可以动态调整的,可以随着数据增加或减少自动对数组长度做更改. 一:创建数组 ...
- 也谈面试必备问题之 JavaScript 数组去重
Why underscore (觉得这部分眼熟的可以直接跳到下一段了...) 最近开始看 underscore.js 源码,并将 underscore.js 源码解读 放在了我的 2016 计划中. ...
- js 判断数组包含某值的方法 和 javascript数组扩展indexOf()方法
var questionId = []; var anSwerIdValue = []; ////javascript数组扩展indexOf()方法 Array.prototype.indexOf ...
随机推荐
- Ubuntu中VMware tools的安装步骤
按照下面的步骤,轻松解决!! 1.点击导航栏中的虚拟机,下面的安装VMware tools 2.点击桌面上的光盘,进入后,将tar.gz文件复制到桌面,然后右击提取到此处: 3.在桌面打开终端,cd到 ...
- Service Mesh - gRPC 本地联调远程服务
Description Service Mesh 架构下,服务间调用会通过服务名(Service Name)互相调用,比如在 Kubernetes .Docker Swarm 集群中,服务 IP 均由 ...
- 学以致用:手把手教你撸一个工具库并打包发布,顺便解决JS浮点数计算精度问题
本文讲解的是怎么实现一个工具库并打包发布到npm给大家使用.本文实现的工具是一个分数计算器,大家考虑如下情况: \[ \sqrt{(((\frac{1}{3}+3.5)*\frac{2}{9}-\fr ...
- spring boot 过滤器 前后端分离跨域sessionId不一致
import org.springframework.stereotype.Component; import javax.servlet.*; import javax.servlet.http ...
- 爬虫之requestsku
想用selenium实现B站自动登录已经点赞等功能,看到如何解决滑动解锁有关爬虫的内容,便开始学习爬虫,没过多久又想把记录自己生活的网站做起来,朋友便推荐了layui框架倒腾了一晚上自我觉得是做后台系 ...
- 【05】openlayers 网格图层
效果: 创建地图: //创建地图 var map = new ol.Map({ //设置显示地图的视图 view: new ol.View({ projection: 'EPSG:4326', //投 ...
- Ajax的封装,以及利用jquery的ajax获取天气预报
1.Ajax的封装 function ajax(type,url,param,sync,datetype,callback){//第一个参数是获取数据的类型,第二个参数是传入open的url,第三个是 ...
- python网络协议
一 互联网的本质 咱们先不说互联网是如何通信的(发送数据,文件等),先用一个经典的例子,给大家说明什么是互联网通信. 现在追溯到八九十年代,当时电话刚刚兴起,还没有手机的概念,只是有线电话,那么此时你 ...
- vscode 自动修复 setting.json 修改完,得重启浏览器 # 新版(>1.41.0)配置 vscode #解决了
vscode 自动修复 setting.json 修改完,得重启浏览器,不用 npm run dev 就能看到效果 "editor.codeActionsOnSave": { &q ...
- 前端构建工具gulpjs的使用介绍及技巧【转载】
转载至:http://www.cnblogs.com/2050/p/4198792.html gulpjs是一个前端构建工具,与gruntjs相比,gulpjs无需写一大堆繁杂的配置参数,API也非常 ...