.map()和.each()的区别

Posted

tags:

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

参考技术A 两者的区别
map()方法主要用来遍历操作数组和对象,each()主要用于遍历jquery对象。
each()返回的是原来的数组,并不会新创建一个数组。
map()方法会返回一个新的数组。如果在没有必要的情况下使用map,则有可能造成内存浪费。

jquery中的each函数和map函数的区别

jquery中的each函数和map函数的用法看起来差不多,但其实还是有一点区别的。

其中一个重要的区别是,each返回的是原来的数组,并不会新创建一个数组。而map方法会返回一个新的数组。如果在没有必要的情况下使用map,则有可能造成内存浪费。

例如:

var items = [1,2,3,4]; 
$.each(items, function() { 
alert(‘this is ‘ + this); 
}); 
var newItems = $.map(items, function(i) { 
return i + 1; 
}); 
// newItems is [2,3,4,5]

使用each时,改变的还是原来的items数组,而使用map时,不改变items,只是新建一个新的数组。

例如:

var items = [0,1,2,3,4,5,6,7,8,9]; 
var itemsLessThanEqualFive = $.map(items, function(i) { 
// removes all items > 5 
if (i > 5) 
return null; 
return i; 
}); 
// itemsLessThanEqualFive = [0,1,2,3,4,5]

当需要对数组进行删除时也是如此,所以删除时错误使用each或map后果还是蛮严重的。


本文出自 “刘博方的博客” 博客,请务必保留此出处http://liubofang.blog.51cto.com/11162557/1792460

以上是关于.map()和.each()的区别的主要内容,如果未能解决你的问题,请参考以下文章

JS的forEach和map方法的区别,还有一个$each

jquery中的each函数和map函数的区别

jquery each 和 map 区别

jQuery 源码解析 $.each和$.map的区别

JS的forEach和map方法的区别,还有一个$.each

$.each()$.map()区别浅谈