[英]why filter return [object Object]?
var persons = [
{name : "jak" , age:20},
{name : "hasan" , age: 15},
{name : "reza" , age:18}
];
function adult(el,index,arr){
if (el.age >= 18)
return el.name;
}
document.getElementById("x").innerHTML = persons.filter(adult);
}
我期望jak和reza,但是我看到[object object] [object object]。
过滤器需要返回true以保留元素,否则返回false。
见下文:
var persons = [{ name: "jak", age: 20 }, { name: "hasan", age: 15 }, { name: "reza", age: 18 }]; function adult(el, index, arr) { if (el.age >= 18) return true; } document.getElementById("x").innerHTML = persons.filter(adult).map(function(person) { return person.name; });
<div id='x'></div>
参考: MDN
您正在看到[object Object], [object Object]
因为您试图将对象数组显示为字符串。 发生这种情况是因为您似乎认为filter
会根据返回值创建一个字符串。 那不是filter
工作原理。 filter
接受一个返回true
或false
的函数,并仅使用返回true
的结果创建一个新数组。
var adults = persons.filter(function(person) {
return person.age >= 18;
});
如果要将数组中的某些元素映射到其他对象,则可以使用map
。
var adultNames = adults.map(function(person) {
return person.name;
});
最后,要将数组转换为单个字符串,可以使用join
。
document.getElementById("x").innerHTML = adultNames.join('and');
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.