10分钟弄懂javascript数组
建议阅读时间 : 10分钟
主要内容:javascript数组的基本概念、属性、方法
新建数组:
var arr01 = ["a","b","c","d"];
var arr02 = new Array("a","b","c","d");
上面的两个方法都可以创建数组 ["a","b","c","d"];
区别:arr02是通过Array类创建,arr01是通过js内部提供的字面量的方式赋值创建。
new Array()括号中可以接收两种类型的参数,第一种:数组的内布值(如上面代码),第二种:一个数字,规定数组的长度(空数组);
数组的取值与赋值
取值:通过下标 arr01[0] 即可取得arr01中的 "a"
赋值:通过下标 arr01[0] = "m" 即可修改arr01种的"a"为"m"
如果赋值的时候下标比原来的长度大,比如 arr01[6] = "k", 那么数组的长度会变成7,其中的5、6位会赋值undefined
数组的长度
通过 arr01.length 获取
也可以通过长度赋值改变,如 arr01.length=3,及修改了长度
当修改的长度小于原来长度的时候,就会去删掉多余下标上的值,如果大于原来的长度,那多出的长度部分就会赋值undefined


数组的遍历
一般的for循环
for(var i=0; i<arr01.length; i++){
console.log(arr01[i]);
}
for in 循环
for( index in arr01){
console.log(arr01[index]);
}
两个循环都能获取数组的所有值
区别:第一种可以循环出所有下标的值,包括没有赋值的下标的值(undefined), 第二种只循环有值得部分,没有赋值的下标不会被循环
数组的常用方法:
join( ) :把数组的所有元素放入一个字符串,通过一个的分隔符进行分隔
var arr01 = ["a","b","c","d"];
var str01 = arr01.join("-"); //输出字符串 a-b-c-d
操作后原数组不变,如果参数传""空字符串,就得到abcd
pop( ):删除并返回数组的最后一个元素
var arr01 = ["a","b","c","d"];
var str01 = arr01.pop(); //str01 为 d
经过上面的操作,arr01变成了["a","b","c"]
push( ):向数组的末尾添加一个或更多元素,并返回新的长度
var arr01 = ["a","b","c","d"];
arr01.push("e");
经过上面的操作,arr01变成了["a","b","c","d","e"]
shift():删除并返回数组的第一个元素
var arr01 = ["a","b","c","d"];
var str01 = arr01.shift(); //str01 为 a
经过上面的操作,arr01变成了["b","c","d"]
unshift():向数组的开头添加一个或更多元素,并返回新的长度
var arr01 = ["a","b","c","d"];
arr01.punshift("e");
经过上面的操作,arr01变成了["e","a","b","c","d"]
reverse():颠倒数组中元素的顺序
var arr01 = ["a","b","c","d"];
arr01.reverse();
经过上面的操作,arr01变成了["d","c","b","a"]
其他方法:
sort( ):对数组的元素进行排序,默认按照第一个字符由小到大排序
concat():连接两个或更多的数组,并返回结果
slice():从某个已有的数组返回选定的元素
splice():删除元素,并向数组添加新元素
多维数组:
其实就是数组内部再包含数组。其操作和一维数组完全一致,比如下面的二维数组:
[
["Name0", "Age0", "Address0"],
["Name1", "Age1", "Address1"],
["Name2", "Age2", "Address2"]
]
完!
10分钟弄懂javascript数组的更多相关文章
- 10分钟弄懂Raft算法
分布式系统在极大提高可用性.容错性的同时,带来了一致性问题(CAP理论).Raft算法能够解决分布式系统环境下的一致性问题. 我们熟悉的ETCD注册中心就采用了这个算法:你现在看的这篇微信公众号文章, ...
- 这一次,彻底弄懂 JavaScript 执行机制
本文转自https://juejin.im/post/59e85eebf265da430d571f89#heading-4 本文的目的就是要保证你彻底弄懂javascript的执行机制,如果读完本文还 ...
- 彻底弄懂 JavaScript 执行机制
本文的目的就是要保证你彻底弄懂javascript的执行机制,如果读完本文还不懂,可以揍我. 不论你是javascript新手还是老鸟,不论是面试求职,还是日常开发工作,我们经常会遇到这样的情况:给定 ...
- [转帖]10分钟看懂Docker和K8S
10分钟看懂Docker和K8S https://zhuanlan.zhihu.com/p/53260098 2010年,几个搞IT的年轻人,在美国旧金山成立了一家名叫“dotCloud”的公司. 这 ...
- 10分钟搞懂toString和valueOf函数(详细版)
首先要说明的是这两种方法是toPrimitive抽象操作里会经常用到的. 默认情况下,执行这个抽象操作时会先执行valueOf方法,如果返回的不是原始值,会继续执行toString方法,如果返回的还不 ...
- 十分钟读懂JavaScript原型和原型链
原型(prototype)这个词来自拉丁文的词proto,意谓“最初的”,意义是形式或模型.在JavaScript中,原型的探索也有很多有趣的地方,接下来跟随我的脚步去看看吧. 原型对象释义 每一个构 ...
- 【前端知识体系-JS相关】10分钟搞定JavaScript正则表达式高频考点
1.正则表达式基础 1.1 创建正则表达式 1.1.1 使用一个正则表达式字面量 const regex = /^[a-zA-Z]+[0-9]*\W?_$/gi; 1.1.2 调用RegExp对象的构 ...
- 一分钟搞懂JavaScript中的JSON对象
JSON(JavaScript Object Notation)是表示值和对象的通用格式. JavaScript 提供了如下方法: JSON.stringify 将对象转换为 JSON. JSON.p ...
- 5分钟弄懂Docker--转载
编者按:7月3日的“CSDN在线培训:Docker之道”,同时在线人数达到了历史新高,但是最后的QA环节,笔者发现大家的问题 还是很初级的,Docker技术还处在Gartner技术曲线的萌芽期.刚好前 ...
随机推荐
- java复习(2)---java基础杂记
java命名规范: 参考:http://www.cnblogs.com/maowang1991/archive/2013/06/29/3162366.html 1.项目名小写 2.包名小写 3.类名每 ...
- struts1实现简单的登录功能(附源码)
环境:MyEclipse 14 ...
- C++学习笔记1(标准的输入输出)
前言: 个人一直以来比较懒,最近才准备记录一下自己学习C++的学习过程,希望自己能在写博客的时候能够坚持下去,欢迎大家在博客中支出存在的问题,好了不多说了,自己能坚持下去.我准备在我的博客中通过与C语 ...
- Android系统--输入系统(九)Reader线程_核心类及配置文件
Android系统--输入系统(九)Reader线程_核心类及配置文件 1. Reader线程核心类--EventHub 1.1 Reader线程核心结构体 实例化对象:mEventHub--表示多个 ...
- 简谈-如何使用Python和R组合完成任务
概述 和那些数据科学比赛不同,在真实的数据科学中,我们可能更多的时间不是在做算法的开发,而是对需求的定义和数据的治理.所以,如何更好的结合现实业务,让数据真正产生价值成了一个更有意义的话题. 数据科学 ...
- CSS3 & SVG 制作钟表
在线演示 源码下载
- OC中Foundation框架之NSString、NSMutableString
创建方式 )直接赋值 NSString *str =@"abc"; )创建对象 NSString *str2 = [[NSString alloc]init]; str2 =@&q ...
- Android的cookie的接收和发送
我在做自动登录的时候遇到的坑,特写此文以提醒各位不要把自己绕进去了. 我们都知道在web端的cookie是可以通过服务器端设置保存的,默认是关闭浏览器就清除cookie的,但是可以在服务器端设置coo ...
- Charles Proxy 4.1.2 破解版
下载Charles Proxy 4.1.2版本,百度云盘下载 或 去官网下载 安装后先打开Charles一次(Windows版可以忽略此步骤) 在这个网站(http://charles.iiilab. ...
- [asp.net mvc 奇淫巧技] 02 - 巧用Razor引擎在Action内生成Html代码
在web开发中经常会遇到在内部代码中获取Html,这些Html是需要和数据进行一起渲染.并不是直接把Html代码返回给客户端.这样的做法有很多应用场景,例如分页.Ajax一次性获取几段Html片段.生 ...