首页 > 其他分享 >7个简单棘手的JS问题

7个简单棘手的JS问题

时间:2024-06-19 23:30:37浏览次数:13  
标签:棘手 const 变量 JavaScript Question JS length 简单 log

文章目录

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

本文整理、转载自:7个简单但棘手的JavaScript面试问题

1. 意外全局变量

Question

以下代码段中用于运算 typeof atypeof b 的内容:

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

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

Answer

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

foo() 范围或全局范围中都没有声明变量b。因此JavaScript将 b = 0 表达式解释为 window.b = 0。换句话说,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() 范围内,而在外部范围内不使用。

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

2.数组的length属性

Question

clothes[0] 的值是什么?

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

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

Answer

数组对象的 length 属性具有特殊的行为:减少length属性的值的副作用是删除自己的数组元素。因此,当JavaScript执行 clothes.length = 0 的时候将删除所有元素。

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

3.鹰眼测试

Question

numbers 数组的内容是什么?

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

numbers; // => ???

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

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

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

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

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

numbers; // => [5]

for()i 变量递增到4,然后JavaScript一次进入块 {number.push(i + 1);},将 4 +1 推入数字数组。

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

4.自动分号插入

Question

arrayFromValue() 返回什么值?

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

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

Answer

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

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

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

arrayFromValue(10); // => undefined

return; 函数内部使其返回 undefined。因此 arrayFromValue(10) 的值为 undefined

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

Question

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

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

Answer

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

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

Phase 1
  1. for() 重复3次,在每次迭代过程中,都会创建一个新的函数 log() 来捕获变量 i。然后 setTimout() 计划执行log()
  2. for() 循环完成时,i 变量的值为 3

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

Phase 2

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

如果您难以理解闭包,建议阅读“ JavaScript闭包的简单说明”

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

6.浮点数计算

Question

这个等式的结果是什么?

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

Answer

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

0.1 + 0.2; // => 0.30000000000000004

0.10.2 的总和不完全是 0.3,而是略高于 0.3

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

简而言之,直接比较浮点数并不精确。

因此 0.1 + 0.2 === 0.3 的结果是 false

点击 0.30000000000000004.com 了解更多信息。

7.变量提升

Question

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

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

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

Answer

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

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

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

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

8.最后…

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

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


原文:https://dmitripavlutin.com/simple-but-tricky-javascript-interview-questions/

作者:Dmitri Pavlutin

翻译:做工程师不做码农

标签:棘手,const,变量,JavaScript,Question,JS,length,简单,log
From: https://blog.csdn.net/Orzak/article/details/139719751

相关文章

  • js 在vscode中让自己的api获得类型提示,成员补全的能力
    我的项目不是正经的js项目,它经常需要单个文件打开,并且调用接口来自另一种语言实现创建API.d.ts文件为接口自动生成类型标记文件,格式如下这里的类型来自另一门语言自动生成,不是js的类型,但我觉得无所谓吧declarenamespaceAPI{ /** *成员的注释 */constAge:String......
  • 深入浅出简单工厂模式及其在 Spring 框架中的应用
    前言在软件开发过程中,我们经常需要创建各种对象。如果直接在客户端代码中使用new关键字来实例化对象,不仅会导致代码耦合度高,还会使系统难以扩展和维护。简单工厂模式通过引入一个工厂类来负责创建对象,降低了客户端与具体类之间的耦合度,提高了代码的灵活性和可维护性。在......
  • SEETF-2023 express-javascript-security ejs相关漏洞
    今天做个ejs相关题目。进入页面只发现一个输入框,题目标签是ejs相关,去github看看源码,发现ejs版本为3.1.9,可以确定地是rce漏洞。接下来说说这个rce漏洞。3.1.9版本的rce漏洞主要是因为使用了这个模板来构建网页逻辑导致的。点击查看代码//index.jsconstexpress=require('e......
  • Java设置JSON字符串参数编码
    1.如何在Java中创建JSON字符串在Java中创建JSON字符串,我们可以使用多个库,其中最流行的是Jackson、Gson和org.json。以下是使用这些库创建JSON字符串的示例:1.1使用Jackson库(1)首先,确保我们的项目中包含了Jackson的依赖(如果我们使用Maven,可以参考前面的示例)。(2)创建一个Java对象(例......
  • threejs纹理平铺实现地面效果
    constgeometry=newTHREE.PlaneGeometry(20000,20000);//纹理贴图加载器TextureLoaderconsttexLoader=newTHREE.TextureLoader();//.load()方法加载图像,返回一个纹理对象Textureconstrenderer=newTHREE.WebGLRenderer();consttexture=texL......
  • 孩子成绩差?方法错了,努力也没用,把握10点,提高成绩很简单
      每次成绩出来,考的好的孩子回到家里,眉飞色舞;考得差的孩子回到家中,垂头丧气。  孩子学习成绩差,家长看在眼里,急在心里,学习不好要如何补救?把握下面10点,提高成绩不难。  1、目标管理法。  饭要一口口吃,路要一步步走,要想提高学习成绩,第一步,先确定好目标。  ......
  • nodejs学习08——会话控制 session cookie token
    会话控制一、介绍所谓会话控制就是对会话进行控制HTTP是一种无状态的协议,它没有办法区分多次的请求是否来自于同一个客户端,无法区分用户而产品中又大量存在的这样的需求,所以我们需要通过会话控制来解决该问题常见的会话控制技术有三种:cookiesessiontoken二、cooki......
  • 网易云简单案例
    importrequests#1.获取单张图片#找到目标urlurl='https://p1.music.126.net/MSAC3foF-V7L_wXo8GWNag==/109951169698511206.jpg?imageView&quality=89'#构造请求头字典headers={'User-Agent':'Mozilla/5.0(Macintosh;IntelMacOSX10_15_7......
  • golang json库 忽略 omitempty
    json库的obmitempty介绍众所周知,golang的json库有个omitempty的tag,有了它,这个json序列化的时候,如果这个字段是零值,则会忽略此字段的序列化,导致json字符串中没有对应的字符串。这对于某些人是困惑的,一般默认是没有omitempty这个tag的,但是。但是来了,但是protobuf生成的pb.......
  • Go中的一些优化笔记,简单而不简单
    转自https://mp.weixin.qq.com/s/X8c6ZIJdBFptYA9CRj6wnA今天小土给大家带来一篇关于Golang项目中最简单的优化的文章。原文见Golang:simpleoptimizationnotes[1]我们这里简单聊一下优化本身,然后我们直接从实际的示例开始。为什么要优化呢?当你资源占有较高的话会需要很......