JavaScript基础——使用数组
Array对象提供存储和处理一组其他对象的一种手段。数组可以存储数值、字符串或其他JavaScript对象。创建JavaScript数组有几种不同的方法。例如,下面的语句穿件同样的驻足的3个相同的版本:
var arr = ["one","two","three"];
var arr2 = new Array();
arr2[0] = "one";
arr2[1] = "two";
arr2[2] = "three";
arr3.push("one");
arr3.push("two");
arr3.push("three");
第一种方法定义了arr,并使用[]在一条语句中设置它的内容。第二种方法创建arr2对象,然后使用直接索引赋值来增加条目。第三种方法创建arr3对象,然后使用扩展数组的最佳选择push()方法来把条目推到数组上。
要确定数组中元素的个数,可以使用数组对象的length属性,如下面的例子所示:
var numOfItems = arr.length;
数组遵循一个从零开始的索引,这意味着第一项在索引0上,等等。例如,在下面的代码中,变量first的值是Monday,变量last的值将是Friday:
var
week = ["Mondy","Tuesday","Wednesday","Thursday","Friday"];
var first = w [0];
var last = week[week.length-1];
数组对象有许多内置的函数,使你可以用不同的方式来访问和操作数组。下表描述了连接到Array对象,让你操作数组内容的方法。
用来操作Array对象的方法
方 法 | 说 明 |
concat(arr1,arr2,...) | 返回一个数组和作为参数传递的数组的连接副本 |
indexOf(value) | 返回数组中value的第一个索引。或如果没有找到该条目,返回-1 |
join(separator) | 把一个数组中的所有元素连接为由separator分隔的单个字符串。如果没有指定分隔符,则使用逗号作为分隔符 |
lastIndexOf(value) | 返回数组中value的最后一个索引。或如果没有找到该条目,返回-1 |
pop() | 删除数组的最后一个元素,并返回该元素 |
push(item1,item2,...) | 添加一个或多个新元素到数组的结尾,并返回数组的新长度 |
reverse() | 反转数组中所有元素的顺序 |
shift() | 删除数组的第一个元素,并返回该元素 |
slice(start,end) | 返回start和end索引之间的元素 |
sort(sortFunction) | 对数组的元素排序。sortFunction是可选的 |
splice(index,count,item1,item2...) | 在index指定的索引处,删除count个条目,然后在index出插入作为参数传入的任意可选条目 |
toString() | 返回一个数组的字符串形式 |
unshift() | 将新元素添加到数组的开头,并返回新的长度 |
valueOf() | 方法返回一个数组对象的原始值 |
1、合并数组
你可以用合并String对象的相同方式来合并数组:使用+语句或使用concat()方法。在下面的代码中,arr3最终和arr4是一样的:
var arr1 = [1,2,3];
var arr2 = ["one","two","three"];
var arr3 = arr1 + arr2;
var arr4 = arr1.concat(arr2);
注意
你可以将一个数字数组和一个字符串数组合并。数组中的每一项都将保持自己的对象类型。然而,当你使用数组中的条目时,需要对有多个数据类型的数组保持跟踪,这样你才不会陷入麻烦。
2、遍历数组
你可以使用for或for/in循环对数组进行遍历。下面的代码说明了使用每种方法再数组中遍历每个条目的写法:
var week = ["Monday","Tuesday","Wednesday","Thursday","Friday"];
for ( var i = 0; i<week.length; i++){
console.log("<li>" + week[i] + "</li>");
}
for (dayIndex in week){
console.log("<li>" + week[dayIndex] + "</li>");
}
3、将数组转换为字符串
Array对象的一个非常有用的功能是,将一个数组的元素结合在一起,制造一个String对象,通过使用join()方法指定分隔符分隔。例如,下面的代码把时间组件重新连接成12:10:36的格式:
var timeArr = [12,10,36]
var timeStr = timeArr.join(":");
4、检查数组是否包含某个条目
你经常需要检查数组中是否包含某一个条目。可以使用indexOf()方法做到这一点。如果代码没有找到列表中的条目,则返回-1。如果一个条目在week数组中,下面的函数就把一条消息写到控制台:
function message(day){
var week = ["Monday","Tuesday","Wednesday","Thursday","Friday"];
if (week.indexOf(day) != -1){
console.log("Happy" + day);
}
}
5、在数组中添加条目和删除条目
使用各种内置的方法,有多种往Array对象添加条目,并从Array对象删除条目的方法。下表列出了一些在本书中使用的不同方法。
用来在数组添加或删除元素的Array对象方法,数组显示为从表开始到末尾的进度
语 句 | x的值 | arr的值 |
var arr = [1,2,3,4,5]; | undefined | 1,2,3,4,5 |
var x = 0; | 0 | 1,2,3,4,5 |
x = arr.unshift("zero"); | 6(长度) | zero,1,2,3,4,5 |
x = arr.push(6,7,8); | 9(长度) | zero,1,2,3,4,5,6,7,8 |
x = arr.shift(); | zero | 1,2,3,4,5,6,7,8 |
x = arr.pop() | 8 | 1,2,3,4,5,6,7 |
x = arr.splice(3,3,"four","five","six"); | 4,5,6 | 1,2,3,four,five,six,7 |
x = arr.splice(3,1); | four | 1,2,3,five,six,7 |
x = arr.splice(3); | five,six,7 | 1,2,3 |
JavaScript基础——使用数组的更多相关文章
- JavaScript 基础回顾——数组
JavaScript是无类型语言,数组元素可以具有任意的数据类型,同一个数组的不同元素可以具有不同类型.数组的元素设置可以包含其他数组,便于模拟创建多维数组. 1.创建数组 在JavaScript中, ...
- javascript基础知识-数组
1.javascript创建数组时无需声明数组大小或者在数组大小变化时重新分配 2.javascript数组是无类型的 3.数组元素不一定要连续 4.针对稀疏数组,length比所有元素的索引都要大 ...
- JavaScript 基础(二)数组
字符串, JavaScript 字符串就是用'' 和""括起来的字符表示. 字符字面量, \n 换行, \t 制表, \b 退格, \r 回车, \f 进纸, \\ 斜杠,\' 单 ...
- JavaScript基础之数组常用方法
目录 JS 数组常用API 常用属性 常用方法 常见方法语法解释 from方法 isArray concat every fill filter find forEach indexOf join k ...
- javascript基础之数组一
<script type="text/javascript"> //求数组中最大的数 var arr=[123,456,789,657,432,564]; var ar ...
- javascript基础之数组对象
一.定义数组的方法: 定义了一个空数组: var myArray =new Array(); 指定有n个空元素的数组: var myArray=new Array(n); 定义数组并赋值: var m ...
- JavaScript 基础(六) 数组方法 闭包
在一个对象中绑定函数,称为这个对象的方法.在JavaScript 中,对象的定义是这样的: var guagua = { name:'瓜瓜', birth:1990 }; 但是,如果我们给瓜瓜绑定一个 ...
- JavaScript基础04——数组的创建及方法
数组的概念及定义 数组的概念: 一组数据,数据的组和 哪些数据的组和,只要是数据(所有数据),就可以放在数组中 数组的意义: 可以同时操作多个数据 数组 ...
- javascript基础系列(入门前须知)
-----------------------小历史---------------------------- javascript与java是两种语言,他们的创作公司不同,JavaScript当时是借 ...
随机推荐
- 剑指Offer 替换空格
题目描述 请实现一个函数,将一个字符串中的空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy. 思路: 替换空格,先遍历一遍记 ...
- SVN迁移到Git的过程(+ 一些技巧
关于在VCS中SVN和Git之间的迁移(Clone)这个部分网上已经有大批的文章介绍,而且都非常不错,能够满足我们的常见的需求,这里介绍的是我自己整理的一些技巧和使用中出现的一些问题和疑问.阅读本篇文 ...
- phpcms的评论改为留言板研究
研究背景: phpcms里面默认是没有留言板的,之前我的博客里发过一个二次开发简介,里面有一个简单的留言板,包含前台提供表单,后台留言审核等功能,但是不提供用户登录等操作. 研究思路: phpcms里 ...
- MySQL表结构及数据的备份
1.Navicat for MySQL 选择要保存的表,右键转储SQL文件,导出的sql文件中包括表的定义和表的数据两部分. 其他办法: (1) create table dust select * ...
- LUA+resty 搭建验证码服务器
使用Lua和OpenResty搭建验证码服务器 雨客 2016-04-08 16:38:11 浏览2525 评论0 云数据库Redis版 摘要: Lua下有个Lua-GD图形库,通过简单的Lua语句就 ...
- Discovering versions from the identity service failed when creating the password plugin.
If you are behind the proxy, then you have to set no_proxy environmental variable for your localhost ...
- How to keep Environment Variables when Using SUDO
The trick is to add environment variables to sudoers file via sudo visudo command and add these line ...
- Redis Sentinel机制与用法(一)
Sentinel spring 集群配置: 概述 Redis-Sentinel是Redis官方推荐的高可用性(HA)解决方案,当用Redis做Master-slave的高可用方案时,假如master宕 ...
- 一个静态的HTML页面用jquery ajax登录到sharepoint页面
$.ajax({ type: "get", url: "http://", d ...
- SHAREPOINT - CAML列表查询
首先要了解的是CAML(Collaboration Application Markup Language)不仅仅是用在对列表.文档库的查询,字段的定义,站点定义等处处使用的都是CAML. 简单的提一 ...