我有一个类似于
的对象 var obj = { 'Earth': 1, 'Sky': 2, 'Tree': 3, 'Sand': 4 };
我正在尝试使用此
基于值进行过滤$.filter(obj,function(i, value){
return value>3;
});
然而,这是空的。
预期产出
{'Sand': 4 }
当对象的索引无法一致地处理并且可能会有所不同时,是否有办法按值进行过滤。
答案 0 :(得分:6)
尝试这样的事情......
function filterObjectProperties(obj, filtercb){
var ret = {};
for(var p in obj)
if(obj.hasOwnProperty(p))
if(filtercb(obj[p]))
ret[p] = obj[p];
return ret;
}
var obj = { 'Earth': 1, 'Sky': 2, 'Tree': 3, 'Sand': 4 };
var newObj = filterObjectProperties(obj, function(val){
return val > 3;
});
答案 1 :(得分:2)
这可以在没有$.filter
的情况下完成:
var obj = { 'Earth': 1, 'Sky': 2, 'Tree': 3, 'Sand': 4 };
result = {};
for (var k in obj) {
if (obj[k] > 3) {
result[k] = obj[k];
}
}
console.log(result);
答案 2 :(得分:1)
你可以JQuery.each()。要使用JQuery.filter和JQuery.grep,我认为你的对象应该形成不同的。
$(function(){
var obj = { 'Earth': 1, 'Sky': 2, 'Tree': 3, 'Sand': 4 };
var result = null;
$.each(obj, function(key, value) {
if(value > 3){
result = key;
}
});
console.log(result);
});
答案 3 :(得分:1)
应该像
一样简单var obj = { 'Earth': 1, 'Sky': 2, 'Tree': 3, 'Sand': 4 };
var result = Object.keys(obj)
.filter(function(e) { return obj[e] > 3 })
.reduce(function(object, property) {
return (object[property] = obj[property], object);
}, {})
没有任何图书馆
答案 4 :(得分:1)
filter
对象没有原生Object
,但是这个怎么样:
var obj = { 'Earth': 1, 'Sky': 2, 'Tree': 3, 'Sand': 4 };
newObject = {}
Object.keys(obj).map(function(value, index) {
if (obj[value]>3){
newObject[value] = obj [value]
}
});
snippet.log(newObject);
// => {'Sand': 4 }

<script src="http://tjcrowder.github.io/simple-snippets-console/snippet.js"></script>
&#13;
答案 5 :(得分:0)
var obj = { 'Earth': 1, 'Sky': 2, 'Tree': 3, 'Sand': 4 };
function filterObj(obj, valueThreshold) {
var keys = Object.keys(obj);
var result = {};
keys.forEach(function(key) {
var value = obj[key];
if (value > valueThreshold) {
result[key] = value;
}
})
return result;
}
console.log('obj: ' + JSON.stringify(obj));
var filteredObj = filterObj(obj, 3);
console.log('filterdObj: ' + JSON.stringify(filteredObj));