$.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循环的主要内容,如果未能解决你的问题,请参考以下文章
为啥我的使用“for-each 循环”的线性搜索代码不适用于混合输入?
前端性能优化:jquery的each为什么比原生的for循环慢很多?
Groovy集合遍历 ( 使用 for 循环遍历集合 | 使用集合的 each 方法遍历集合 | 集合的 each 方法返回值分析 )