我试图在lodash javascript库中找出,如何找出过滤器数组对象的多个键值.类似于SQL的东西 – (val1,val2)中的WHERE KEY
说完了,举例如下:
var users = [
{ 'user': 'barney', 'age': 36, 'active': true },
{ 'user': 'fred', 'age': 40, 'active': false },
{ 'user': 'Avding', 'age': 34, 'active': true }
];
_.filter(...)
我怎样才能找到年龄在34,36岁的用户?
数字也可以改变运行时间
解决方法:
Lodash的filter接受谓词.您可以使用部分应用程序创建谓词,以便轻松更改值:
var users = [
{ 'user': 'barney', 'age': 36, 'active': true },
{ 'user': 'fred', 'age': 40, 'active': false },
{ 'user': 'Avding', 'age': 34, 'active': true }
];
var predicate = function(start, end) {
return function(user) {
return _.inRange(user.age, start, end + 1);
}
}
var result = _.filter(users, predicate(34, 36));
console.log('inRange', result);
/** is equal predicate **/
var predicate = function() {
var args = _.toArray(arguments);
return function(user) {
var equalToUserAge = _.partial(_.isEqual, user.age);
return args.some(equalToUserAge);
}
}
var result = _.filter(users, predicate(34, 40));
console.log('equals', result);
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.16.4/lodash.min.js"></script>
您也可以使用vanilla JS轻松完成此操作(示例使用ES6):
var users = [
{ 'user': 'barney', 'age': 36, 'active': true },
{ 'user': 'fred', 'age': 40, 'active': false },
{ 'user': 'Avding', 'age': 34, 'active': true }
];
const predicate1 = (start, end) => ({ age }) =>
age >= start && age <= end;
const result1 = users.filter(predicate1(34, 36));
console.log('in range', result1);
const predicate2 = (...args) => ({ age }) =>
args.some((num) => age === num);
const result2 = users.filter(predicate2(34, 40));
console.log('is equal', result2);