[英]forEach takes an array and a callback
我需要帮助解决这个问题,因为我不明白:(。请帮忙!
forEach 函数接受一个数组和一个回调。 它在数组的每个元素上运行回调——就是这样!
var alphabet = '';
var letters = ['a', 'b', 'c', 'd'];
forEach(letters, function(char) {
alphabet += char;
});
console.log(alphabet); //prints 'abcd'
**(underneath is is where I edit)**
// Challenge 4
function forEach(array, callback) {
}
// see for yourself if your forEach works!
我不知道你到底想实现什么,但你的代码不是惯用的 JavaScript ......
核心 JavaScript 语言已经提供了一个可以直接使用的forEach
方法。 请阅读以下页面: Array.prototype.forEach()
当您使用forEach
,您的代码应如下所示:
var alphabet = '',
letters = ['a', 'b', 'c', 'd'];
letters.forEach(function (letter) {
alphabet += letter;
});
console.log(alphabet);
但是,如果您担心性能泄漏,您可能希望改用具有缓存长度的传统for
循环。
var alphabet = '',
letters = ['a', 'b', 'c', 'd'];
for(var i = 0, len = letters.length; i < len; i++) {
alphabet += letters[i];
}
console.log(alphabet);
感谢 ES6,您还可以在可迭代对象(如数组)上使用for...of
循环。 这是现代 JavaScript 应用程序中的推荐指令:
let alphabet = '',
letters = ['a', 'b', 'c', 'd'];
for (const letter of letters) {
alphabet += letter;
}
console.log(alphabet);
但由于开发人员有时很懒惰,最好的答案可能是这个:
var letters = ['a', 'b', 'c', 'd'],
alphabet = letters.join('');
console.log(alphabet);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.