Javascript的常规数组和关联数组对比小结
2012-05-24 00:00
513 查看
首先我们看看数组的分类:
从数组的下标分为索引数组、关联数组
问题:你可以如下测试:
alert(arry1.length); // 返回值为:4
alert(arry2.length); //返回值为:0
这是因为什么呢,因为js是非类型语言,所以js 的任何类型都是object,
比如var arr = [];
arr[0] = 1;
arr[1] = 2;
arr[2] = 3;
arr["s"] = 4;
此时你调用arr.s相当于是在调用arr这个对象的s属性,但是这是arr.length仍然是3。
总结:关联数组虽然可以用字符串作下标,但是这个下标是不支持参数传值的,换言之,你需要什么就取什么,听起来很智能,实际上你取值仍然需要你手动去写下标的。
从数组的下标分为索引数组、关联数组
/* 索引数组,即通常情况下所说的数组 */ var ary1 = [1,3,5,8]; //按索引去取数组元素,从0开始(当然某些语言实现从1开始),索引实际上就是序数,一个整型数字 ary1[0]; ary1[1]; ary1[2]; ary1[3]; /* 关联数组,指以非序数类型为下标来存取的数组 python中称为字典 */ var ary2 = {}; //存取时,以非序数(数字),这里是字符串 ary2["one"] = 1; ary2["two"] = 2; ary2["thr"] = 3; ary2["fou"] = 4;
问题:你可以如下测试:
alert(arry1.length); // 返回值为:4
alert(arry2.length); //返回值为:0
这是因为什么呢,因为js是非类型语言,所以js 的任何类型都是object,
比如var arr = [];
arr[0] = 1;
arr[1] = 2;
arr[2] = 3;
arr["s"] = 4;
此时你调用arr.s相当于是在调用arr这个对象的s属性,但是这是arr.length仍然是3。
总结:关联数组虽然可以用字符串作下标,但是这个下标是不支持参数传值的,换言之,你需要什么就取什么,听起来很智能,实际上你取值仍然需要你手动去写下标的。
相关文章推荐
- Javascript的常规数组和关联数组对比小结
- Javascript 的常规数组 和 关联数组 对比!
- JavaScript中数组slice和splice的对比小结
- JavaScript中数组slice和splice的对比小结
- javascript中数组、关联数组、对象的基本对比
- JavaScript中数组slice和splice的对比小结
- JavaScript中数组slice和splice的对比小结
- javascript中讨论关联数组和对象的区别
- 关于JavaScript中的关联数组分析
- javascript进行数组追加方法小结
- JavaScript sort数组排序方法和自我实现排序方法小结
- javascript php 数组 json 对比 总结
- 每天一篇javascript学习小结(Array数组)
- JavaScript数组倒序算法与性能对比
- javascript和php中的数组处理函数对比
- javascript中的关联数组
- javascript中数组和字符串的方法对比
- JavaScript常用数组算法小结
- JQuery 操作Javascript对象和数组的工具函数小结