记录--7 个沙雕又带有陷阱的 JS 面试题

这篇具有很好参考价值的文章主要介绍了记录--7 个沙雕又带有陷阱的 JS 面试题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助

记录--7 个沙雕又带有陷阱的 JS 面试题

为了保证的可读性,本文采用意译而非直译。

在 JS 面试中,经常会看到一些简单而又沙雕的题目,这些题目包含一些陷阱,但这些在我们规范的编码下或者业务中基本不会出现。 有些面试官就是这样,不专注于制定代码的标准和规范上,却用不规范的代码去检验别人是否细心。

这魔幻的世界就是一个攀比优越感的,我能考你,我就是比你优越,真实。

来看看这 7 个沙雕题目是哪些。

1. 偶然创建的全局变量

面试官问

在下面的代码中 typeof atypeof b 结果各自是什么?(沙雕)

function foo() {
  let a = b = 0;
  a++;
  return a;
}

foo();
typeof a; // => ???
typeof b; // => ???

答案

这个代码的重点在第二行:let a = b = 0。这个语句声明了一个局部变量 a,但是它也声明了一个全局变量b

foo() 作用域或全局作用域中都没有声明变量 b。因此 JS 引荐将b = 0 表达式解释为 window.b = 0

如下图所示,函数 foo 中的 i 都是一个偶然创建的全局变量:

记录--7 个沙雕又带有陷阱的 JS 面试题

 同样,在咱们的问题中,b 是一个偶然创建的全局变量。在浏览器中,上面的代码相当于如下:

function foo() {
  let a;
  window.b = 0;
  a = window.b;
  a++;
  return a;
}

foo();
typeof a;        // => 'undefined'
typeof window.b; // => 'number'

typeof a'undefined'。变量 a 仅在 foo() 作用域中声明,在外部作用域内不可用。

typeof b 结果是 'number'b 是一个值为 0 的全局变量

2. 数组的 length 属性

面试官问

clothes[0] 的值是什么?(沙雕)

const clothes = ['jacket', 't-shirt'];
clothes.length = 0;

clothes[0]; // => ???

答案

数组对象的 length 属性具有一些特殊的行为:

减少 length 属性的值的副作用是删除 自己的 数组元素,这些元素的数组索引位于新旧长度值之间。

由于 length 属性行为,当 JS 执行 clothes.length = 0 时,删除所有的 clothes 项。 所以 clothes[0] 的值为 undefined,因为 clothes 数组已被清空。

3.考验眼力的魔幻题

面试官问

下面代码中 numbers 数组的内容是什么? 注意 for() 后加了一个分号(;),真是沙雕

const length = 4;
const numbers = [];
for (var i = 0; i < length; i++);{
  numbers.push(i + 1);
}

numbers; // => ???

答案

上面代码中 for() 后加了一个分号(;) ,加上分号,JS 会认为该语句结束,所以 for 循环执行了4次空语句,当退出循环的时候,此时的 i 值为 4。

然后执行 { numbers.push(i + 1); },所以最终 numbers 内容只有一个数字 5

上面的代码相当于下面的代码

const length = 4;
const numbers = [];
var i;
for (i = 0; i < length; i++) {
  // does nothing
}
{ 
  // a simple block
  numbers.push(i + 1);
}

numbers; // => [5]    
    

用不规范的代码去检验别人是否细心,我觉得很沙雕。

4.自动分号插入

面试官问

arrayFromValue() 返回什么值?(沙雕)

function arrayFromValue(items) {
  return
    [items];
}

arrayFromValue(10); // => ???

答案

这里需要注意的 return 和 [items] 之间已经换行了,JS 会在换行之间自动插入分号。所以上面等价下面的代码:

function arrayFromValue(items) {
  return;
  [items];
}

arrayFromValue(10); // => undefined

return;在函数内部使该函数返回 undefined,所以 arrayFromValue(10) 的值为 undefined

5. 被考烂的一个经典闭包问题

面试官问

下面的代码执行结果是什么?(能不能换个题)

let i;
for (i = 0; i < 3; i++) {
  const log = () => {
    console.log(i);
  }
  setTimeout(log, 100);
}

答案

当你对 JS 基础不是很了解的时候,很容易给出 0, 1, 2 的答案,我第一次在学校遇到这个题目也是这个答案。

执行这段代码的过程有两个阶段。

阶段1

  1. for() 迭代 3 次。在每次迭代时,都会创建一个新函数 log(),该函数将捕获变量 i。然后,setTimout() 调度 log() 的执行。

  2. for() 循环完成时,变量 i 的值为 3

log() 是一个捕获变量 i 的闭包,该变量在 for() 循环的外部作用域中定义。重要的是要了解闭包在词法上捕获了变量 i

阶段 2

第二阶段发生在 100 毫秒之后

setTimeout()调用 3log() 回调。log() 读取变量 i 的当前值,即 3

这就是为什么控制台输出为 333 的原因

6. 浮点运算

面试官问

下面的代码输出是什么? (能不能换个题)

0.1 + 0.2 === 0.3 // => ???

答案

首先,来看一下 0.1 + 0.2 的值

0.1 + 0.2; // => 0.30000000000000004

0.10.2 的和不等于 0.3,但略高于 0.3

由于以二进制方式对浮点数进行编码,因此像浮点数相加之类的操作会产生舍入误差。

因此, 0.1 + 0.2 === 0.3false

7. 变量的提升

面试官问

如果在声明之前访问 myVarmyConst 会发生什么?(能不能换个题)

myVar;   // => ???
myConst; // => ???

var myVar = 'value';
const myConst = 3.14;    

答案

提升和时间死区是影响 JS 变量生命周期的两个重要概念。

记录--7 个沙雕又带有陷阱的 JS 面试题

在声明之前访问 myVar 的结果是 undefined,因为使用 var 声明的变量会被提升且值为 undefined

但是,在声明行之前访问 myConst 会引发 ReferenceError。在代码行 const myConst = 3.14 之前,const 变量处于临时死区。

本文转载于:

https://juejin.cn/post/6844903974374473736

如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。

 记录--7 个沙雕又带有陷阱的 JS 面试题文章来源地址https://www.toymoban.com/news/detail-475848.html

到了这里,关于记录--7 个沙雕又带有陷阱的 JS 面试题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vue3结合three.js实现3D带有交互的动画

    three.js引入 安装轨道控件插件: 安装渲染器插件: vue文件中引用: 在页面中创建场景 创建一个透视相机 初始化渲染器 初始动画混合器 参数:rootObject 混合器播放的动画所属的对象。就是包含动画模型的场景对象。 常用参数和属性: .time 全局的混合器时间。 .clipAction(Ani

    2024年02月04日
    浏览(55)
  • 记录一次最近遇到的新网络诈骗经历,大家要提高警惕啊

    第一次接到诈骗电话,说是要求修改支付宝信息的,一开始说的确实是很迷惑人,一下子可能没法马上分辨出来,但是到后面说要加QQ操作什么什么的,那肯定就是有严重问题的,因为很多诈骗都是通过QQ来操作的,一听到这个就要警惕了。 他的诈骗流程是这样的: 先是说你

    2023年04月23日
    浏览(44)
  • 自适应插件autofit.js使用(这里演示vue项目)

    这个插件使用以后,页面会根据浏览器的缩放自适应的改变宽高 这里演示的是vue3项目,其他项目也可类似去写 如果要在整个项目做自适应,将配置配到App.vue,如果只要单个页面自适应,只需要配置当前页面即可 App.vue配置如下(单个页面自适应也是如此配置) 以下代码三步走

    2024年02月04日
    浏览(42)
  • Tomcat面试题+http面试题+Nginx面试题+常见面试题

    1、Tomcat的缺省端口是多少?怎么修改? 答:缺省端口是8080,若要修改,可以进入Tomcat的安装目录下找到conf目录下的server.xml文件,找到该文件中的Connector字段中的port。 2、Tomcat有哪几种connector运行模式(服务的请求方式)? 答:三种。修改它的运行模式需要在主配置文件中

    2023年04月10日
    浏览(44)
  • Linux常见面试题,应对面试分享

    1.cpu占⽤率太⾼了怎么办? 排查思路是什么,怎么定位这个问题,处理流程 其他程序: 1.通过top命令按照CPU使⽤率排序找出占⽤资源最⾼的进程 2.lsof查看这个进程在使⽤什么⽂件或者有哪些线程 3.询问开发或者⽼⼤,是什么业务在使⽤这个进程 4.是否可以将这台机器隔离,不影响

    2024年02月13日
    浏览(45)
  • FPGA面试试题(附个人整理答案)

    一、什么是FPGA,内部资源构成?        答:FPGA(Field-Programmable Gate Array,现场可编程门阵列)是一种可以通过编程来配置的半导体设备。FPGA由成千上万个 可配置逻辑块 (CLB)和 可编程的互联资源 组成,可以实现复杂的数字计算功能。与其他类型的集成电路相比,如专用

    2024年04月11日
    浏览(58)
  • 【面试】面试官问的几率较大的网络安全面试题

    攻击者在HTTP请求中注入恶意的SQL代码,服务器使用参数构建数据库SQL命令时,恶意SQL被一起构造,并在数据库中执行。 用户登录,输入用户名 lianggzone,密码 ‘ or ‘1’=’1 ,如果此时使用参数构造的方式,就会出现 select * from user where name = ‘lianggzone’ and password = ‘’ or

    2024年02月01日
    浏览(52)
  • js常见面试题整理

    1:JavaScript 有哪些数据类型 答: JavaScript 的数据类型分为原始类型和对象类型。 原始类型有 7 种,分别是: Boolean Number BigInt String Null Undefined Symbol 对象类型(也称引用类型)是一个泛称,包括数组、对象、函数等一切对象。  2:typeof null 的结果是什么 判断一个类型为  n

    2024年02月07日
    浏览(41)
  • java面试常问,zookeeper常见面试题

    什么是 Spring Boot? 为什么要用 Spring Boot? Spring Boot 的核心配置文件有哪几个?它们的区别是什么? Spring Boot 的配置文件有哪几种格式?它们有什么区别? Spring Boot 的核心注解是哪个?它主要由哪几个注解组成的? 开启 Spring Boot 特性有哪几种方式? Spring Boot 需要独立的容器

    2024年03月15日
    浏览(67)
  • 程序员面试系列,docker常见面试题

    原文链接 什么是Docker?它的主要作用是什么? Docker和虚拟机之间有什么区别? Docker的主要组件有哪些? Docker镜像和容器的区别是什么? 如何构建Docker镜像?请简要描述构建过程。 如何创建和启动一个Docker容器? 如何在Docker容器内运行后台任务? Docker的网络模式有哪些?

    2024年02月15日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包