
本文详解如何正确遍历包含对象的数组,筛选出 score 大于 4 的雇员姓名,纠正初学者常见的索引误用、嵌套冗余和逻辑断点问题,并提供返回单个结果与全部匹配结果两种实用方案。
在 JavaScript 中处理“数组 + 对象”的组合结构是入门阶段的关键技能。你提供的代码目标明确:从 employers 数组中找出所有 score > 4 的雇员姓名并输出。但原始实现存在几个典型误区,我们逐一剖析并给出专业、可扩展的解决方案。
❌ 原代码主要问题分析
- 冗余嵌套:let List = [employers]; 将本已是数组的 employers 再包一层,导致 List 变成二维数组([[{...}, {...}, ...]]),后续 List[i]['score'] 必然报错(undefined);
- 索引缺失:if(List['score'] > 4) 错误地将整个数组当作对象访问,且未使用循环变量 i 访问具体元素;
- 过早终止:return 在循环内首次命中即退出函数,仅返回第一个匹配项(如存在多个高分雇员则被忽略);
- 参数未使用:函数形参 employerList 被声明却未使用,实际操作的是全局 employers,违背函数封装原则。
✅ 正确做法:两种常用场景
场景一:仅需返回第一个匹配姓名(适合“找某人”类需求)
function getFirstHighScorer(employerList) {
for (let i = 0; i < employerList.length; i++) {
if (employerList[i].score > 4) { // 直接用点号访问更简洁
return employerList[i].name;
}
}
return null; // 无匹配时返回明确值,避免 undefined
}
console.log(getFirstHighScorer(employers)); // "Adam"✅ 优势:高效、短路执行;⚠️ 注意:若需确保返回值存在,建议添加兜底返回(如 null 或空字符串)。
场景二:返回所有匹配姓名数组(推荐用于通用筛选)
function getHighScorers(employerList) {
const result = [];
for (let i = 0; i < employerList.length; i++) {
if (employerList[i].score > 4) {
result.push(employerList[i].name);
}
}
return result;
}
// 更现代、声明式的写法(推荐)
function getHighScorersModern(employerList) {
return employerList
.filter(emp => emp.score > 4) // 筛选对象
.map(emp => emp.name); // 提取姓名
}
console.log(getHighScorersModern(employers)); // ["Adam"]✅ filter() + map() 组合是函数式编程的标准实践:语义清晰、不可变、易于测试与复用。
? 扩展提示:若需返回完整对象(不止姓名),直接 filter() 即可;若需格式化输出(如 "Adam (score: 5)"),可在 map() 中定制字符串。
? 关键注意事项
- 永远验证数据类型:传入函数前确认 employerList 是数组(可用 Array.isArray(employerList) 防御);
- 避免修改原数组:filter/map 不改变原数组,而 push() 在新数组操作,符合安全编程习惯;
- 边界情况处理:空数组、无匹配项、score 为 null/undefined 时,emp.score > 4 会隐式转为 NaN > 4 → false,相对安全;但严谨场景建议先校验 typeof emp.score === 'number';
- 命名规范:函数名应体现意图(如 getHighScorers 比 getEmployer 更准确),变量名用小驼峰(employerList 而非 List)。
掌握这种“遍历→条件判断→提取/收集”的模式,是你迈向处理真实数据(如 API 响应、表单列表)的重要一步。多练习 filter/map/reduce 这类高阶数组方法,代码将更简洁、健壮且富有表现力。










