$.each循环

Posted 专注前端开发

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了$.each循环相关的知识,希望对你有一定的参考价值。

一、语法

//一维数组
var arr = [1,2,3,4,5];
$.each(arr, function(){
  console.log(this);
});
$.each(arr, function(index,ele){
  console.log(index + ‘:‘ + ele);
});
//二维数组
var arr = [[1, 4, 3], [4, 6, 6], [7, 20, 9]]
$.each(arr, function(i, item){
  console.log(item[0]);
});
//遍历对象属性
var obj = { one:1, two:2, three:3, four:4};
$.each(obj, function(key, val) {
  console.log(obj[key]);
  //console.log(key + ‘:‘ + val);
});

$.each()可用于遍历任何集合(无论是数组或对象),如果是数组,回调函数每次传入数组的索引和对应的值,方法会返回被遍历对象的第一参数。

$.each()循环里,没有break,continue,可以有return。return alse跳出本次循环并执行循环体后的代码,return true结束本次循环执行下一次循环。

结合jquery源码, 当对象中存在length属性时,$.each 内部使用for循环去遍历对象,,否则它将使用for in循环去遍历。

二、执行效率

var arr = [],
    arrlen = arr.length = 1000000;
for(var i=0; i<arrlen; i++){
  arr[i] = ‘looptest‘;
}
var t1 = +new Date();
$.each(arr, function(i, ele){
});
var t2 = +new Date();
console.log(‘$.each:‘ + (t2-t1));

比every慢。

以上是关于$.each循环的主要内容,如果未能解决你的问题,请参考以下文章

jquery $.each()循环退出

@each 带索引的循环

为啥我的使用“for-each 循环”的线性搜索代码不适用于混合输入?

Jquery each方法跳出循环,并获取返回值实例讲解

前端性能优化:jquery的each为什么比原生的for循环慢很多?

Groovy集合遍历 ( 使用 for 循环遍历集合 | 使用集合的 each 方法遍历集合 | 集合的 each 方法返回值分析 )