美文网首页让前端飞Web前端之路
7 个沙雕又带有陷阱的 JS 面试题

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

作者: web前端学习圈 | 来源:发表于2020-06-13 17:19 被阅读0次

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

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

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

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

1. 偶然创建的全局变量

面试官问

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

答案

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

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

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

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

functionfoo(){leta;window.b =0;  a =window.b;  a++;returna;}foo();typeofa;// => 'undefined'typeofwindow.b;// => 'number'

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

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

2. 数组的 length 属性

面试官问

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

答案

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

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

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

3.考验眼力的魔幻题

面试官问

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

答案

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

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

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

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

4.自动分号插入

面试官问

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

答案

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

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

面试官问

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

答案

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

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

阶段1

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

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

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

阶段 2

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

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

这就是为什么控制台输出为 3, 3 和 3 的原因

其实还有一种解释,就是计算机执行一条语句基本都是纳秒级别的,所以执行一个简单循环根本花费不了多少,当 100 毫秒后,for 早就跑完了,变量 i 已经是退出循环的条件值。

6. 浮点运算

面试官问

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

答案

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

0.1 和 0.2 的和不等于 0.3,但略高于 0.3。

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

因此, 0.1 + 0.2 === 0.3 是 false。

7. 变量的提升

面试官问

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

答案

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

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

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

总结


你有没有感觉上面的问题,有些是对面试毫无用处,特别是第3道题目。但是,还是有一小部分的面试中会被问到。

当然,虽然都说是沙雕题目,但这些是可以评估你是否精通 JS,还是有我们学习的知识的。

在面试中,你还遇到哪些像这样的题目,欢迎留言讨论。

<<<前端是我一辈子的信仰,写代码直到50岁>>>

关注微信公众号:web前端学习圈

回复关键词【简书】送你50G最适合2020年学习的web前端零基础入门教程(视频+笔记+素材+源码+项目实战)

另外公众号每天都会分享学习方法,知识干货,实战案例,面试技巧,经验分享等相关文章,关注web前端学习圈=关注5000+前端大牛

相关文章

  • 7 个沙雕又带有陷阱的 JS 面试题

    为了保证的可读性,本文采用意译而非直译。 在 JS 面试中,经常会看到一些简单而又沙雕的题目,这些题目包含一些陷阱...

  • 7 个沙雕又带有陷阱的 JS 面试题

    为了保证的可读性,本文采用意译而非直译。 在 JS 面试中,经常会看到一些简单而又沙雕的题目,这些题目包含一些陷阱...

  • 有一个沙雕对象是什么样的体验?

    今天跟大家讨论的是: 有一个沙雕对象是什么样的体验 来看看沙雕们是怎么秀恩爱的吧 —以上— 沙雕的生活真是欢乐多又...

  • 舟山之旅

    7月9日,我和妈妈去舟山旅游。第二天的下午,我们去舟山的朱家尖看沙雕,那里有很多沙雕,这些沙雕雕刻得非常漂亮,有白...

  • 又皮又沙雕的文案

    01 我多么希望 有人能看出我的脆弱 对我说: “穷逼,地址给我 双十一想要什么我给你买。” 02 螺丝厂的工作 ...

  • 沙雕室友的日常

    我有三个室友,划分一下代号 欣欣~沙雕一号 妮妮~沙雕二号 维维~沙雕三号 郎郎~沙雕四号 先来细数一下沙雕室友一...

  • 家常琐事之沙雕总集

    家常琐事 之 沙雕总集 我本身就是个沙雕,所以自然而然就有吸雕体质。 有个沙雕友友,我们当年同住时,租的房子空落落...

  • 开心又沙雕的文案

    1.恋爱太难了 拜个把子吧 2.请问你是秋高吗 我快被你气爽了 3.你早起 我早起 我们迟早在一起 4.你好 我是...

  • 可爱又沙雕的文案:

    1.最近圆了许多 我的可爱又多了一吨 2.太累了 抽一名幸运网友为我扛下所有 3.今天有点不开心,虽然不是你造成的...

  • 我的沙雕朋友

    我有一个沙雕朋友他的名字叫做王亚慧 他是真的沙雕啊 沙雕到什么程度呢 就是那种你看着他就会想到沙雕这两个字 但是就...

网友评论

    本文标题:7 个沙雕又带有陷阱的 JS 面试题

    本文链接:https://www.haomeiwen.com/subject/eflztktx.html