[size=medium]_.find(list, predicate, [context]) Alias: detect
在list中逐项查找,返回第一个通过predicate迭代函数真值检测的元素值,如果没有值传递给测试迭代器将返回undefined。 如果找到匹配的元素,函数将立即返回,不会遍历整个list。
_.filter(list, predicate, [context]) Alias: select
遍历list中的每个值,返回包含所有通过predicate真值检测的元素值。
以上是http://www.css88.com/doc/underscore/中的介绍。
刚开始时,我认为find与filter的区别就是:find找到第一个匹配的元素便停止遍历,返回第一个匹配的元素,而filter是遍历并返回找到的所有匹配元素。所以我觉得如果在一个没有重复元素的数组中进行遍历并返回值时,用find和filter是没有区别的。但是,实际操作时发现find是返回一个值,而filter是把匹配的结果放到一个数组中再返回,也就是说filter返回的是一个数组。
举个简单的例子:[/size]
在list中逐项查找,返回第一个通过predicate迭代函数真值检测的元素值,如果没有值传递给测试迭代器将返回undefined。 如果找到匹配的元素,函数将立即返回,不会遍历整个list。
_.filter(list, predicate, [context]) Alias: select
遍历list中的每个值,返回包含所有通过predicate真值检测的元素值。
以上是http://www.css88.com/doc/underscore/中的介绍。
刚开始时,我认为find与filter的区别就是:find找到第一个匹配的元素便停止遍历,返回第一个匹配的元素,而filter是遍历并返回找到的所有匹配元素。所以我觉得如果在一个没有重复元素的数组中进行遍历并返回值时,用find和filter是没有区别的。但是,实际操作时发现find是返回一个值,而filter是把匹配的结果放到一个数组中再返回,也就是说filter返回的是一个数组。
举个简单的例子:[/size]
var num = [1,2,3,4,5];
var a = _.find(num, function(num){
return num == 2;
}); //a的结果是:2
var a = _.filter(num, function(num){
return num == 2;
}); //a的结果是[2]