7个简单但棘手的JavaScript面试问题

大家好,我是做工程师不做码农!聚焦大前端技术和程序员成长的干货公众号,点击关注,每天给你精彩!

7个简单但棘手的JavaScript面试问题

我在软件开发中最需要强调的事情是:

  • 编码面试
  • 一个比较”毒“(toxic)的经理或队友d ( - ] 2 s |

如果您符合高级开发人员的资格,其工作涉及JavaScript,那么在编码面试中很有可能会被问到r r p b棘手的问题。

遵循这个建议:“熟能生巧”。深入有规律地学习JavaScript将提高您的编码能力,并且可以提高您的面试技巧。

在这篇文章中,你会发现7个乍一看很简单但很棘手的JavaScript面试问l } } & { ) M+ H Z d 7 b m b

虽然一开始这些问题看起来是随意的,但是它们试图与JavaScript的重要概念挂钩。所以你最好在下次面试前练习一下!

7个简单但棘手的JavaScript面试问题

1. 意外全局变量

问题

以下代码段中用于运算a M } ) = J n typeof atypeof b内容

functio / ) y } 4 : #n foo() {
let a = b = 0;
a++;
return a;
}

fooX n $ = I 2 w();
typeof a; // => ???
typeof b; // => ???

答案

让我们看一下第2行:let a = b = 0C [ w o该语句声明一个局部变量a,然儿,它也声明了全局变量b。

foo() 范围或全局范围中都没有声明变量b。因此JavaScript将 b = 0 表达式解释为 window.b = 0。换句话说,b是i o O k意外创建的全局变量P k 7 g } M } C u

7个简单但棘手的JavaScript面试问题

在浏览器中,以上代码片段等效于:

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

foo();
typeof a; // =X C D [ x> \'undefined\'
typeof window.b; // => \'number\'

type4 c L G r P bof a 等于 \'undefined\',变量 a 存在于 foo() 范围内,而在外部范围内不使用。

因为b是一个值为0的全局变量,所以b的类型的值为 \'number\'

2.数组的length属性

问题

clothes[0] 的值是什么?

const clothes = [\'jacke6 ! E + ! h t\', \'t-shirt\'];
clothes.length = 0;

clo8 4 A @ m F [ 1 mthes[0]; // =>m | w; ???

答案

数组对象的 lengL m J % 8th 属性具有特殊的行为:减少length属性的值的副作用是删除自己的数组元素。d b y M _ g ] Q因此,+ v ] h当JavaScript执行 clothes.length = 0 的时候将删除所A 2 !有元素。

clothes [0] 等于 undefined 的,因为 clothes 数组已被清空。

3.鹰眼测试

问题

numberz U # ^ o @ A xs 数组的内容是什么?

const length = 4;
const numbers = [];
for (vaB % S Qr i = 0; i < length; i++);{
numbers.pus[ E 6 v Sh(i + 1);
}

numbers; // =U K / l U> ???

让我们仔细看一下分号 出现在左大括号 {

7个简单但棘手的JavaScript面试问题

这个分号很容易被忽略,它创建了一个空语句。空语句是不做任何事情的空语句。

for() 在空语句上进行4次迭代(不执行任何操作),而忽略实际% A L / d项目推入数组的块:{number.push(i + 1);}。上面的代码等效于以下代码:

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

numbers; // =>| A X X [ { % 8 $; [5]

for() 将 i 变量递增到4,然后JavaSk X XcN x Pript一次进入2 E I N{number.push(i d t + 1);},将 4 +1 推入数字数组。

因此,numbers 数组的内容为 [5]

4.自动Q 0 # e分号插入

问题

arrayFromValue() 返回什d 2 Z l - Y I么值?

fuc f e ] fnction arrayFromValue(item) {
return
[item];
}

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

答案

很容易错过 return 关键字和 [item] 表达式之间的换行符。此换行符使JavaScript自动在 return[item] 表达式之间插入分号a 0 7 i p

这是h [ n 2等效的代码,在返回后插入了分号:

function arrayFromValue(i7 E ; { stem) {
return;
[item];
}

arrayFromVaA z U Y ;lue(10); // => uT G &ndefined

return; 函数内部使其返回 undefined。因此 arrayFromValue(10) 的值为 undefinedC I G { w c z

5.经典问题:棘手的闭包

问题

以下代码将输出什么到控制台?

let i;
for (Q Y (i = 0; i & V $ u i u T & Mlt; 3; i++) {I r 7
cl = :onst log = () => {
console.log(i);
}
setTimeout(log, 100);
}

答案

如果您以前从未听说过这个棘手的问题,则很可能您的答案是 0、1 和 2:这是错误的。当我第( A # ?一次尝试解决它时,这也是我的答案!

执行此代码段有两个阶段。

Phas] / 2 Te 1:

  1. for() 重复3次,在每次迭代过程中,都会M | # @ v创建一R 5 a U a I c个新的函数 log() 来捕获变量 i。然后 setTimout() 计] Z ~ ) E划执行log()。
  2. 当 for() 循环完成时,i 变量的值为 3。

log() 是一个捕获变量 i 的闭包,该变量在 for() 循环的外部范围中定义。请务必注意,闭包可以词法捕获 i 变量。

Phase 2:第二} % P l 3 4 u v阶段发生在100ms之后:setTimeout() 调用了3次计划的 log() 。log() 读取变量i的当前值为3,并记录到控制台3。这就是为什么控制台输出为3、3 和 3 的原因。

您知道如何将代码段记录为0、1和2吗?请在下面的评论中写下您的解- 4 @ e决方案!

6f . M % `.浮点数计算

问题8 O b q e Z q 0

这个等式的结果是? Z | 2什么?

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

答案

首先,让我们看一下 0.1 + 0.2 的值:

0.1 + 0.2; // => 0.30000000000000004

0.1 和 0.2C V | 3 b w 的总和不完全是 0.3,而是略高于 0.3。

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

# x e v m 9 Q B而言之,直接B @ t f &比较浮点数并不精确。

因此 0.1 + 0.2 === 0.3 的结2 m Y E I : 9 c果是 false

7.变量提升

问题

如果在声明前访问 myVar 和 myConst,会发生什么情况?

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

var myVn 3 k } g 7 4 f 2ar = \'value\';
const myConst = 3.14;

答案

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

7个简单但棘手的JavaScript面试问题

在声明之0 S前访问 myVar 的结果为 undefined。在初始化之前,提升的 var 变量具有 undefined 的值。

然儿,在声明行之前访问 myConst 会引发 ReferenceErrorconst 变量处于临时死区B k a I C f b,直到声明行 const myConst = 3.14

8.最后...

您可以认为某些问题( S i A x z ,对面试毫无用处。我有同样的感觉,特别是关于鹰眼测试。尽管如此,他们可能会被问到。

无论如何,其中许多问题都可以真正e K % ^ ( B :评估您是否精通JavaScript,1 y % 0 X ! r例如棘手的闭包。如果您在阅读帖子时遇到一些困难,这很好地表明了您接下来必须学习什么!

在面试中提出棘手的问题是否公平?让我知道你的意见。

#前端面试题# #web前端面试# #每日学习JavaScript# #程序员#

上一篇

漫威最暗黑宇宙!钢铁侠被开颅取宝石,美国队长成为红骷髅亲爹?

下一篇

超高质量电影推荐,剧荒的朋友可以看看(第二弹)

评论已经被关闭。

插入图片
返回顶部