其表现形式就是内存中的一段连续的内存地址
数组名称其实就是连续内存地址的首地址
2、关于js中的数组特点
数组定义时无需指定数据类型
数组定义时可以无需指定数组长度
数组可以存储任何数据类型的数据(比如说一个元素保存整型,一个元素保存字符串型,这个在JS中是可以的)
js中创建数组的语法:
var arr = [值1,值2,值3]//隐式创建
var arr = new Array(值1,值2,值3)//直接实例化
var array = new Array(size)//创建数组并指定长度
JS中符号含义:
() 表示函数执行
[] 表示语法模拟,表示模拟Array类的实例(=new Array())
{} 表示语法模拟,表示模拟Object类的实例(=new Object())
// 表示语法模拟(正则对象),表示模拟RegExp类的实例(=new RegExp())
3、关于数组长度
数组对象.length
在js中,每一个数组对象都可以调用length属性,它表示数组对象下共有几个数组元素
示例:
var row = ['zhangsan','lisi','wangwu']
console.log('共有'+row.length+'个人')//输出: 共有3个人
var length = row.length//对数组进行遍历
for (var i=0i<lengthi++){
console.log(row[i])//输出: zhangsan lisi wangwu
}
4、for...in语句
在js中,数组不是数据类型,数组的数据类型其实就是对象
Js中的For.....in语句可以实现对一个对象的所有属性的遍历
也可以使用for...in语句实现对一个数组的所有元素的遍历
语法:
for( var i in array ){
}
原理:数组中有几个元素,for..in语句就循环执行多少次
var row = ['zhangsan','lisi','wangwu','xiaoqiang']
for (var i in row){
console.log(i + ':' + row[i] + '<br>')
}
// 输出结果为: 0:zhangsan 1:lisi 2:wangwu 3:xiaoqiang
5、文本下标
格式:
arr['key'] = value
在js中,文本下标的数组元素,不计入数组长度
以文本下标形式添加到数组,实际是以属性形式添加到数组对象中的。
Array.of() 的作用是 创建数组 。
创建数组本来已经有 字面量 和 Array构造函数 等方法,但由于 Array构造函数 创建数组时有一些怪异的行为,所以 ES6 添加了 Array.of() 来弥补 Array构造函数 的不足。
以上是 Array构造函数 的用法,也是 Array构造函数 的怪异行为。
new Array() 当只传入一个参数时,不能传入负数,也不能传入浮点数。
在使用 new Array 时,一不小心就会创建出稀疏数组。这个动作会产生一些诡异的“空槽”行为,这也是JS数组广为人所诟病的一点。
Array.of() 取代了 Array() 成为数组的推荐函数形式构造器,因为 Array.of() 并没有这个特殊的单一数值型参数值的问题。
Array.of() 总是返回参数值组成的数组。如果没有参数就返回一个空数组。
所以说,Array.of() 的行为比 Array() 更统一。
如果有一个回调函数需要传入的参数封装为数组,而且不能保证传入的值一定不是0或正整数,Array.of()可以完美解决这个问题。
如果需要构建 Array 的子类,并且想要在子类实例中创建和初始化元素。
这里用了reduce方法,这个方法是Array的,这里用 this.reduce 是因为 Calculator 继承了 Array。
Array.reduce的使用方法可以看下面的链接
【JS】遍历数组的常用方法(举例版)
浏览器上点F12
代码:
<script>
var writerInfoArr = new Array()//js的数组不要设置长度,我们就当他是4个。
var writerInfo = new Object()
for(var i=0i<4i++){
writerInfo.name="《故事会》"writerInfo.author="张三"writerInfo.addr="建平村1号"writerInfo.len=5
writerInfoArr[i]=writerInfo
}
console.log(writerInfoArr)
</script>