在 JavaScript 中如何正确声明一个数组? 下面本篇文章给大家介绍一下 JavaScript 声明数组的方法. 有一定的参考价值, 有需要的朋友可以参考一下, 希望对大家有所帮助.
什么是数组
数组就是一组数据的集合
其表现形式就是内存中的一段连续的内存地址
数组名称其实就是连续内存地址的首地址
关于 JS 中的数组特点
数组定义时无需指定数据类型
数组定义时可以无需指定数组长度
数组可以存储任何数据类型的数据 (比如说一个元素保存整型, 一个元素保存字符串型, 这个在 JS 中是可以的)
创建数组的语法:
var arr=[值 1, 值 2, 值 3]; // 隐式创建
- var arr=new Array(值 1, 值 2, 值 3); // 直接实例化
- var array=new Array(size); // 创建数组并指定长度
方法:
- // 方法一
- var arr1 = [1,3,5,7,9];
- document.write(arr1[2] + '<br>');
- // 方法二
- var arr2 = new Array(2,4,6,8,10);
- document.write(arr2[3] + '<br>');
- // 方法三
- var arr3 = new Array(3);// 固定数组长度为 3
- arr3[0] = 1;
- arr3[1] = 2;
- arr3[2] = 3;
- document.write(arr3[2] + '<br>');
JS 中符号含义:
() 表示函数执行
[] 表示语法模拟, 表示模拟 Array 类的实例 (=new Array())
{} 表示语法模拟, 表示模拟 Object 类的实例 (=new Object())
// 表示语法模拟 (正则对象), 表示模拟 RegExp 类的实例 (=new RegExp())
关于数组长度
数组对象. length
在 JS 中, 每一个数组对象都可以调用 length 属性, 它表示数组对象下共有几个数组元素
示例:
- var row = ['zhangsan','lisi','wangwu'];
- doucument.write('共有'+row.length+'个人 < br>');
- var length = row.length;// 对数组进行遍历
- for (var i=0;i<length;i++){
- doucument.write(row[i]+'<br>');
- }
for...in 语句
在 JS 中, 数组不是数据类型, 数组的数据类型其实就是对象
JS 中的 For.....in 语句可以实现对一个对象的所有属性的遍历
也可以使用 for...in 语句实现对一个数组的所有元素的遍历
语法:
- for( var i in array ){
- }
原理: 数组中有几个元素, for..in 语句就循环执行多少次
每次执行时, 将当前数组元素的下标存放到变量 i 中
- var row = ['zhangsan','lisi','wangwu','xiaoqiang'];
- for (var i in row){
- document.write(i + ':' + row[i] + '<br>');
- }
结果:
- zhangsan
- lisi
- wangwu
- xiaoqiang
文本下标
格式:
arr['key'] = value;
在 JS 中, 文本下标的数组元素, 不计入数组长度
以文本下标形式添加到数组, 实际是以属性形式添加到数组对象中的
- var arr = [1,2,3];
- arr['first'] = 'zhangsan';
- arr['second'] = 'lisi';
- document.write(arr.length + '<br>');
- document.write(arr.first + '<br>');
- document.write(arr.second + '<br>');
结果:
- 3
- zhangsan
- lisi
遍历带有文本下标的数组:
- var arr = [1,2,3];
- arr['first'] = 'zhangsan';
- arr['second'] = 'lisi';
- for(var i in arr){
- document.write(i + ':' + arr[i] + '<br>');
- }
结果:
- 0:1
- 1:2
- 2:3
- first:zhangsan
- second:lisi
多维数组
- var arr = [
- [10,'zhangsan','male'],
- [11,'lisi','female'],
- [12,'wangwu','male']
- ];
- for (var i in arr){
- for(var j in arr[i]){
- document.write(arr[i][j]);
- }
- document.write('<br>');
- }
更多 web 前端 https://www.html.cn/ 知识, 请查阅 HTML 中文网 !!
来源: http://www.css88.com/qa/javascript/18447.html