1、最简单的死循环 for(;;){} 2、 var arr = [33,5,8,5,2,6] for(i in arr){ alert(i) // 下标 0 1 2 3 4 5 alert(arr[i]) // 值 33 5 8 5 2 6 } 3、break 单独使用break语句的作用是立即退出最内层的循环或switch语句。 JS中同样允许break关键字后面跟随一个语句标签(只有标识符,没有冒号)。程序将跳转到这个标签所标识的语句块的结束。 break labelname; 4、continue语句和break语句类似。 在不同类型的循环中,continue的行为也有所区别: 在while循环中,在循环开始处指定的expression会重复检测,如果检测结果为true,循环体会从头开始执行; 在do/while循环中,程序的执行直接跳到循环结尾处,这时会重新判断循环条件,之后才会继续下一次循环; 在for循环中,首先计算自增表达式,然后再次检测test表达式,泳衣判断是否执行循环体。 在for/in循环中,循环开始遍历下一个属性名,这个属性名赋给了指定的变量。 5、数组直接量的语法允许有可选的结尾的逗号 [,,]只有两个元素而非三个 6、数组的索引是基于零的32位数值 0 ~ (2^32-2) 7、可以使用负数或非整数来索引数组,这种情况下,数值转换为字符串,字符串作为属性名来用,而非数组的索引。 如果使用了非负整数的字符串,它就当做数组索引,而非对象属性。 8、Object.prototype.toString.call(obj)返回对象的数据类型 格式为 "[object Array]" 字符串类型 通过 .slice(8,-1) 截取字符串得到数据类型。 9、数组创建方式 var a1 = [,,,] 数组是[undefined,undefined,undefined] var a2 = [undefined]; var a3 = new Array(3) 数组根本没有元素 alert(0 in a1); false alert(0 in a2); true alert(0 in a3); false 10、数组的length属性 arr.length = 0 会改变原数组 可以用Object.defineProperty()让数组的length属性变成只读属性 var a = [1,2,3] Object.defineProperty(a, 'length', {writable: false}) a.length = 0 a不会改变 11、可以像删除对象属性一样使用delete运算符来删除数组元素 var a = [1,2,3] delete a[1] // a[1] = null alert(a) // 1,,3 alert(a.length) // delete操作并不影响数组长度 alert(1 in a) //false, 数组索引1并未在数组中定义 12、数组遍历优化 for(var i=0;i<arr.length;i++){} for(var i=0, len=arr.length;i<len;i++){} 当数组可能是稀疏数组时,使用数组元素之前应该先检测它们, 若想排除null, undefined和不存在的元素 for(var i=0;i<arr.length;i++){ if(!arr[i]) continue; // 跳过null, undefined和不存在的元素 } 若只想跳过undefined和不存在的元素 for(var i=0;i<arr.length;i++){ if(arr[i] === undefined) continue; // 跳过undefined和不存在的元素 } 若只想跳过不存在的元素而仍然要处理存在的undefined元素 for(var i=0;i<arr.length;i++){ if(!(i in arr)) continue; // 跳过undefined和不存在的元素 } 13、ECMA5定义了一些遍历数组元素的新方法,按照索引的顺序传递给定义的函数,如 forEach()方法 var data = [1,2,3,4,5] data.forEach(function(x){ ...... }) 14、排列字符串数组 a = ['ant', 'Bug', 'cat', 'Dog']; a.sort(); //区分大小写的排序:['Bug', 'Dog', 'ant', 'ant', ] a.sort(function(s,t){ // 不区分大小写的排序:ant,Bug,cat,Dog var a = s.toLowerCase(); var b = t.toLowerCase(); if(a < b) return -1; if(a > b) return 1; }) 15、数组操作concat() var a = [1,2,3] a.concat(4,[5,[6,7]]) // [1, 2, 3, 4, 5, [6,7]] 16、toString() 针对数组,该方法将其每个元素转化为字符串(如有必要将调用元素的toString()方法),并且输出用逗号分隔的字符串系列。注意,输出不包括方括号或其他任何形式的包裹数组值的分隔符。与不加任何参数的.join()方法类似; [1,2,3].toString() 生成'1,2,3' ['a','b','c'].toString() 生成'a,b,c' [1,[2,'c']].toString() 生成'1,2,c'