这道JS笔试题你做对了吗?

简介: 昨天在看一道笔试题的时候本以为很简单,但是结果不是我想象的那样,直接上笔试题。


总结回顾


背景


昨天在看一道笔试题的时候本以为很简单,但是结果不是我想象的那样,直接上笔试题。


const array = new Array(5).map((item) => {
  return item = {
    name: '1'
  }
});
console.log(array);
// 请写出输出结果

我想象的答案:[{name: '1'}, {name: '1'}, {name: '1'}, {name: '1'}, {name: '1'}];

实际的答案:[empty × 5]

为什么会这样了?


猜想1


我第一个想到的是new Array(5)生成的数组是[undefined, undefined, undefined, undefined, undefined]。


const array = [undefined, undefined, undefined, undefined, undefined];
const newArr = array.map((item) => {
  return item = {
     name: '1'
   }  
});
console.log(newArr);
// 结果是[{name: '1'}, {name: '1'}, {name: '1'}, {name: '1'}, {name: '1'}];


猜想1错误


猜想2


new Array(5)生成的数组在每一项都没有值,意思就是生成了[,,,,,]一个这样的数组。


const array = [,,,,,];
const newArr = array.map((item) => {
  return item = {
     name: '1'
   }  
});
console.log(newArr);
// 结果是[empty × 5];

猜想2正确(这里大喊自己牛逼)


为什么


map calls a provided callback function once for each element in an array, in order, and constructs a new array from the results. callback is invoked only for indexes of the array which have assigned values (including undefined).

It is not called for missing elements of the array; that is:

  • indexes that have never been set;
  • which have been deleted; or
  • which have never been assigned a value.


map依次为数组中的每个元素调用一次提供的callback函数,然后根据结果构造一个新的数组。-----仅对已分配值(包括)的数组索引进行调用----。 map函数的回调函数只会被赋过值的项调用。new Array(1) 和 [undefined]不一样。new Array(1)没有为数组中的项赋过值,而[undefined]为数组中的项赋了一个undefined值。


总结


  • new Array(5)产生的数组是一个没有为数组中的项赋过值的数组。
  • map仅对已分配值(包括)的数组索引进行callback调用。


优化处理


// 处理1
const array = new Array(5).fill().map((item) => {
  return item = {
    name: '1'
  }
});
console.log(array);
// [{name: '1'}, {name: '1'}, {name: '1'}, {name: '1'}, {name: '1'}];
// 处理2
var array = Array.apply(0,{length:5}).map((item) => {
  return item = {
    name: '1'
  }
});
console.log(array);
// [{name: '1'}, {name: '1'}, {name: '1'}, {name: '1'}, {name: '1'}];
目录
相关文章
|
缓存 运维 容灾
入行5年,谈谈我在阿里做测试开发的经验
作者在阿里一直从事测试开发相关工作,这几年学习很多、收获很多,作者希望给还在该方向摸爬滚打的同学一些启发和方向。
|
机器学习/深度学习 数据采集 供应链
使用Python实现智能食品库存管理的深度学习模型
使用Python实现智能食品库存管理的深度学习模型
568 63
|
7月前
|
Web App开发 缓存 JavaScript
Android网络小说阅读器的实现
小说阅读Demo,。此Demo使用Jsoup解析HTML,实现小说数据抓取(数据源自网络),并包含自定义View、六章小说缓存等功能,但未实现下载。项目还包括屏幕适配、字体设置等,借助第三方框架完成优化。以下是主页、详情页、阅读页等界面展示。
194 0
|
传感器 安全 物联网
蓝牙5.0:革新无线通信的新时代
蓝牙5.0:革新无线通信的新时代
866 12
|
存储 监控 安全
端口安全:交换机上的网络守护者
【8月更文挑战第27天】
374 1
IDEA之Stream表达式生成、调试
IDEA之Stream表达式生成、调试
521 1
|
前端开发 数据中心
数据中心框式交换机如何配置堆叠?
数据中心框式交换机如何配置堆叠?
421 0
|
自然语言处理 监控 搜索推荐
【大模型】探索LLM在各个行业的潜在未来应用
【5月更文挑战第7天】【大模型】探索LLM在各个行业的潜在未来应用
|
存储 安全 Java
Java list set map等接口及其实现类
Java list set map等接口及其实现类
204 0
|
存储 前端开发 安全
酒店客房管理系统设计与实现(代码+数据库+文档)
酒店客房管理系统设计与实现(代码+数据库+文档)