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

news2024/11/29 22:40:29

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

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

在 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 都是一个偶然创建的全局变量:

 同样,在咱们的问题中,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 变量生命周期的两个重要概念。

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

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

本文转载于:

https://juejin.cn/post/6844903974374473736

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

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/626104.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于BP神经网络的轨迹跟踪研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

NLP(1):Introduction

文章目录 Why process textChallengesText processingword, sentence, document, corpus, tokenProcessing stepsSentence segmentationWord TokenizationMaxMatch AlgorithmSubword Tokenization &#xff08;BPE&#xff09;BPE 算法 Word NormalizationStop Words Remove Wh…

数据分析第17课seaborn绘图

关系型绘图 seaborn.relplot() 这个函数功能非常强大,可以用来表示多个变量之间的关联关系。默认情况下是绘制散点图(散点图是看到变量与变量之间相关性最优的一个图形),也可以绘制线性图,具体绘制什么图形是通过kind参数来决定的。实际上以下两个函数就是relplot的特例…

Vue2 事件的默认和传播行为、事件修饰符

前言 在学习vue2时&#xff0c;学到了 事件修饰符&#xff0c;但是对事件的默认行为和传播行为不太理解&#xff0c;所以也就是不知道为啥要使用事件修饰符&#xff0c;所以找了一些资料&#xff0c;在此记录一下。 Vue2官方文档 事件处理 — Vue.js (vuejs.org)https://v2.…

【 Python 全栈开发 - WEB开发篇 - 29 】MySQL初步

文章目录 一、MySQL介绍二、SQL语言三、MySQL安装与配置第一步&#xff1a;下载压缩文件第二步&#xff1a;解压第三步&#xff1a;配置第四步&#xff1a;登录 一、MySQL介绍 MySQL 是一个开源的关系型数据库管理系统&#xff0c;它使用 Structured Query Language&#xff0…

JDBC的增删改查

文章目录 前言创建数据库基础版JDBC实例添加JDBC实例删除JDBC实例修改JDBC实例查询 高级版JDBC实例添加JDBC实例删除JDBC实例修改JDBC实例查询 前言 JDBC编程步骤&#xff1a; 加载数据库驱动程序创建数据库连接对象创建Statement语句对象&#xff08;createStatement、prepa…

谈谈聚簇索引与非聚簇索引

技术主题 聚簇索引是一种数据的存储方式,它的数据行只存放在索引(B+树)的叶子上,内部节点不存放数据。 聚簇索引 聚簇索引默认是主键,如果没有定义主键,innodb会选择一个唯一的非空索引代替。如果没有这种索引,innodb会隐式定义一个主键作为聚簇索引。 非聚簇索引 非…

百度出品,Nature重磅 -- 优化的mRNA设计算法可改善mRNA的稳定性和免疫原性

摘要 尽管mRNA疫苗已用于COVID-19的预防&#xff0c;但仍然面临不稳定和易降解的风险&#xff0c;这是mRNA疫苗存储、配送、效价等面临的重要障碍。先前的研究已表明&#xff0c;增加二级结构可延长mRNA的半衰期&#xff0c;再加上选择优化的密码子&#xff0c;可改善蛋白表达。…

Django实现接口自动化平台(五)httprunner(2.x)基本使用【持续更新中】

上一章&#xff1a; Django实现接口自动化平台&#xff08;四&#xff09;解决跨域问题【持续更新中】_做测试的喵酱的博客-CSDN博客 下一章&#xff1a; 一、参考地址&#xff1a; 使用说明_httprunner2.0 概述及使用说明 二、介绍 HttpRunner是一款面向 HTTP(S) 协议的通…

一文带你了解MySQL之锁

目录 一、解决并发事务带来问题的两种基本方式1.1 一致性读&#xff08;Consistent Reads&#xff09;1.2 锁定读&#xff08;Locking Reads&#xff09;1.2.1 共享锁和独占锁1.2.2 锁定读的语句 1.3 写操作 二、多粒度锁三、MySQL中的行锁和表锁3.1 其他存储引擎中的锁3.2 Inn…

高通KMD框架详解

和你一起终身学习&#xff0c;这里是程序员Android 经典好文推荐&#xff0c;通过阅读本文&#xff0c;您将收获以下知识点: 一、概览二、核心模块解析三、模块初始化四、处理UMD CSL请求 一、概览 利用了V4L2可扩展这一特性&#xff0c;高通在相机驱动部分实现了自有的一套KMD…

未来3年,请善待你的工作

作者| Mr.K 编辑| Emma 来源| 技术领导力(ID&#xff1a;jishulingdaoli) “如果不是现在环境差&#xff0c;下家不好找&#xff0c;我早TM跟那个傻X老板翻桌子走人了&#xff0c;这破公司我真是一天都不想待…”这是一位粉丝朋友给K哥私信中的一段话。类似同款的话&#xff…

百度推出基于大模型的代码编写助手“Comate”真的好用吗?

‍ 点击蓝字 关注我们 关注并星标 从此不迷路 计算机视觉研究院 公众号ID&#xff5c;计算机视觉研究院 学习群&#xff5c;扫码在主页获取加入方式 计算机视觉研究院专栏 Column of Computer Vision Institute 6月6日&#xff0c;在文心大模型技术交流会&#xff08;成都&…

从业务出发,K8S环境自建和非自建整体架构设计比较

新钛云服已累计为您分享751篇技术干货 随着数字化转型的大潮到来&#xff0c;越来越多的企业开始上云&#xff0c;同时也纷纷加入到微服务和K8S队伍中。但在K8S整体环境究竟应该用自建的还是非自建&#xff1f;以及他们需要用到的服务&#xff0c;究竟应该自建还是直接用PAAS服…

02.加载GDT表,进入保护模式

加载GDT表&#xff0c;进入保护模式 加载GDT表&#xff0c;实现操作系统从实模式进入保护模式 参考 操作系统学习 — 启动操作系统&#xff1a;进入保护模式 保护模式与实模式 GDT、GDTR、LDT、LDTR 调用门与特权级 趣谈 Linux 操作系统 在01.硬盘启动盘&#xff0c;加载操作系…

要能力、要稳定也要降本——百度多媒体技术回顾

摘要&#xff1a;多媒体技术生态进入到存量市场&#xff0c;客户既要又要还要成为常态。如何将能力、质量与稳定性、成本不断优化&#xff0c;就是各个多媒体技术平台的必修课。本文以百度智能视频云为例&#xff0c;纵览了其在RTC、边缘计算、视频编码等关键能力与用户体验和成…

腾讯搜索的系统架构是如何达到99.994%高可用的?

&#x1f449;腾小云导读 本文主要是搜索在稳定性治理实践的经验总结&#xff0c;讲述了搜狗搜索在技术债治理基础上如何将可用性提升一个量级&#xff0c;事故级 MTTD&#xff08;平均故障检测时间&#xff09;、MTTR&#xff08;平均响应时间&#xff09;优化一个量级&#x…

chatgpt赋能python:Python的IDLE运行方式

Python的IDLE运行方式 Python是一种非常流行的编程语言&#xff0c;其优雅简洁的语法和丰富的库资源&#xff0c;使得Python在很多领域都得到广泛应用。在Python的开发过程中&#xff0c;IDLE是一种常用的Python集成开发环境&#xff08;IDE&#xff09;&#xff0c;对于初学者…

关于操作系统调度器的三篇论文

【引子】没有忘记&#xff0c;目前从事的是DingOS 操作系统相关工作&#xff0c;没有因为LLM 而迷失。LLM 会成为基础设施&#xff0c;LLM 会为操作系统赋能&#xff0c;但是操作系统的价值是客观存在的&#xff0c;除非&#xff0c;计算机体系结构发生了翻天覆地的变化。 在任…

Java面试都只是背答案吗

Java 八股文面试当然要背&#xff0c;不背很难通过面试的 Java基础 Java基础面试题 Java的特点Java 与 C 的区别JDK/JRE/JVM三者的关系Java程序是编译执行还是解释执行&#xff1f;面向对象和面向过程的区别&#xff1f;面向对象有哪些特性&#xff1f;数组到底是不是对象&a…