参考自<<JavaScript权威指南 第6版>>, 直接上代码和注释
//可以包含不同类型的元素 var misc = [1.1,2,true,"string"]; //省略的元素会被设置为undefined var misc = [1,,,3]; //数组是特殊的对象, 支持动态扩展 var misc = ["hello"]; misc[1] = "roger"; misc[2] = 100; //本质上,数组的索引就是对象属性名的一种特殊类型, 所以js中数组没有越界的概念, 当试图查询不存在属性时,返回undefined. //-- 所以完全可以使用负数和非整数来索引数组, 这种情况下数值转换为字符串, 字符串作为属性名用. misc[-1.23] = true; //可能是被单独保存, 就像对象的属性一样被记录.console.log(misc["-1.23"]); misc["1000"] = 100; misc[0.000] = "world"; // 会把 "hello" 修改, 因为索引转化为字符串 '0' console.log(misc.length); //长度是1001 //在数组末尾添加 misc.push("string");
//判断数组 var a = []; console.log(typeof(a)); //使用typeof返回值是 "object" console.log(Array.isArray(a)); // 可以使用Array.isArray(obj)判断: "true" console.log(Array.isArray({})); // 对象不是数组 : "false" //数组的操作 var array = ["a","1","b","2","C"]; //---join()--- console.log(array.join("-")); // 用 - 连接数组元素, 不改变原数组 //---reverse()--- array.reverse(); //直接在原数组中重排 console.log(array); // [ 'C', '2', 'b', '1', 'a' ] //---sort()--- temp = array.sort(); //直接对原数组排序,改变原数组,同时返回排好序的原数组 console.log(temp === array); // 返回的数组就是原数组 console.log(array);//[ '1', '2', 'C', 'a', 'b' ] array.sort(function(s,t){//接收一个比较函数 var a = s.toLowerCase(); var b = t.toLowerCase(); return a<b; }); console.log(array); //----concat()--- console.log(array.concat(["d","f"])); // 不会修改原始数组, 创建新数组连接后返回 //---slice()---- console.log(array.slice(0,-1)); //[ 'C', 'b', 'a', '2' ], 返回切片, 不修改原数组 console.log(array.slice(0)); //[ 'C', 'b', 'a', '2', '1' ] //---splice()---, 参数: 删除/插入的位置(或称操作位置), 操作元素个数, 插入的元素, 返回删除的元素组成的数组 console.log(array.splice(4)); //[ '1' ] 删除索引4后面的所有元素 console.log(array); // [ 'C', 'b', 'a', '2' ] 修改了原始数组 array.splice(2,0,'k','r'); console.log(array);//[ 'C', 'b', 'k', 'r', 'a', '2' ] //---push/pop, unshift/shift //...so easy...