那里有两个问题,一个是 JSHint 警告你的,一个是更根本的问题。
JSHint 警告您的是,理论上,每次循环运行时,都会创建一个新函数。这会更好:
for ( var person in people ) {
person.forEach(handlePerson);
}
function handlePerson(item) {
console.log(item)
}
我说“理论上”是因为虽然规范要求每次都创建一个新的函数对象,但这并不意味着引擎不能重用函数的底层实现,也不意味着引擎不能重用如果您没有为它分配任何其他属性或保留对它的引用,则相同的函数对象。我问了 V8 的人(V8 是 Chrome 中的 JavaScript 引擎),他们说 Chrome 将“......在大多数情况下......”为在同一点创建的不同函数对象重用底层函数实现源代码,并且他们会“期望”大多数其他引擎也会这样做。
所以在这种特殊情况下,JSHint 可能有点过头了。但这通常是一个有用的警告,特别是如果您在循环内创建的函数引用了在循环期间内容发生变化的变量,这是人们犯的经典闭包错误。
但更根本的是,person
是 a String
(它是 中的属性名称people
),并且String
没有forEach
. 你自找的:
for ( var person in people ) {
people[person].forEach(handlePerson);
}
function handlePerson(item) {
console.log(item)
}
...例如,people[person]
获取该键的数组。