2018 – 2022 年前端 JavaScript 面试题(收藏)

本篇文章给大家总结了一些2018 – 2022 年前端 javascript 面试题,有着一定的参考价值,现在分享给大家,希望能帮助到大家!

2018 – 2022 年前端 JavaScript 面试题(收藏)

【相关推荐:前端面试题(2022),前端面试题(2022)】

我们真的是在编写代码,还是像乐高积木一样简单地组装代码?

在 2020 年底,我们仍然看到大多数面试者被问到 AJAX 时,面试者依然在 jQuery 语境中回答问题。这种差距还有很多典型的例子:

CSS Grid 和 Flexbox 布局已经得到了广泛支持。然而,CSS 面试时仍然集中在多列浮动布局 和行内块级元素居中。他们依然对 Bootstrap 或 Foundation 网格系统有着永不消亡的热情。

立即学习“Java免费学习笔记(深入)”;

模块打包器(Module bundler)现在几乎是大规模应用程序的标配。然而,当谈到架构时,我们谈论的又是 minification(压缩) 和 concatenation(合并) 。在访面试中我们真正讨论过多少次 Webpack ?

如果 97% 的代码来自 NPM ,但面试的重点缺又是数组排序或对象迭代。更糟糕的是,我们仍然对 typeof null 很感兴趣。为什么不能聊点 选择合适的库,框架或工具的理性方法呢?

我们仍在让面试者在原型之上进行经典继承,但并不是要验证对这些错误想法的需要。我们有更多的功能性模式。当然,使用 JavaScript class(类),新引入的私有和静态属性可以好好的讨论一下。这将使人们更好地理解面试者的想法,关键决策等。

缓存讨论仍局限于 Cache control headers(控制头) 和 CDN。像 IndexDB,HTTP/2 或Service Workers 这样的东西只是路过。

这种例子不胜枚举,面试评估与工作实际需求之间的差距显而易见。一方面,我们的前端技术实现取得了跨越式发展,另一方面,新的开发方式还没有形成大的社区。社区分裂永远不是好兆头。这是一条灾难之路。差距总是会创造出一种新的东西,它有能力摧毁我们迄今为止所建造的一切。我无法想象 Java 开发人员使用 GWT 编写另一个 Facebook 。

面试是催生变革和汇聚人才的好方式。作为面试官的你,如果仅仅把面试当成面试,那么它只会让你自我膨胀。

       要使一场面试成功,必须进行讨论。 它必须是一个交换思想的地方。 它应该挑起人们思考并客观地分析给定的问题。 它是理解人们做出的决策过程,也是了解一个人对技术和解决问题的热情,也意味着了解未来可能的同事。 所有那些难题,技巧或 typeof null 都无法称得上真正面试。

以下是我们在面试讨论中提出的一些问题清单。我们希望此清单可以帮助面试官和面试者在正确的背景下设定期望,需求和现实。

         TLDR; 我们要先把自己当成面试官。

JavaScript 基础问题

1.使以下代码正常运行:

JavaScript 代码:

const a = [1, 2, 3, 4, 5]; // Implement thisa.multiply(); console.log(a); // [1, 2, 3, 4, 5, 1, 4, 9, 16, 25]

登录后复制

2.以下代码在 JavaScript 中返回 false 。 解释一下为什么会这样:

JavaScript 代码:

// false0.2 + 0.1 === 0.3

登录后复制

3.JavaScript 中有哪些不同的数据类型?

提示:只有两种类型 – 主要数据类型和引用类型(对象)。 有 6 种主要类型。

4.解决以下异步代码问题。

检索并计算属于同一教室中每个学生的平均分数,其中一些ID为75。每个学生可以在一年内参加一门或多门课程。 以下 API 可用于检索所需数据。

JavaScript 代码:

// GET LIST OF ALL THE STUDENTSGET /api/studentsResponse:[{    "id": 1,    "name": "John",    "classroomId": 75}]// GET COURSES FOR GIVEN A STUDENTGET /api/courses?filter=studentId eq 1Response:[{   "id": "history",   "studentId": 1}, {   "id": "algebra",   "studentId": 1},]// GET EVALUATION FOR EACH COURSEGET /api/evaluation/history?filter=studentId eq 1Response:{    "id": 200,    "score": 50,    "totalScore": 100}

登录后复制

编写一个接受教室 ID 的函数,您将根据该函数计算该教室中每个学生的平均值。该函数的最终输出应该是具有平均分数的学生列表:

JavaScript 代码:

[  { "id": 1, "name": "John", "average": 70.5 },  { "id": 3, "name": "Lois", "average": 67 },]

登录后复制

使用普通的 callbackspromisesobservablesgeneratorasync-wait 编写所需的函数。尝试使用至少 3 种不同的技术解决这个问题。

5.使用 JavaScript  Proxy 实现简单的数据绑定

提示:ES Proxy 允许您拦截对任何对象属性或方法的调用。首先,每当更改底层绑定对象时,都应更新 DOM 。

6.解释 JavaScript 并发模型

您是否熟悉 Elixir,Clojure,Java 等其他编程语言中使用的任何其他并发模型?

提示:查找事件循环,任务队列,调用栈,堆等。

7.new 关键字在 JavaScript 中有什么作用?

提示:在 JavaScript 中,new 是用于实例化对象的运算符。 这里的目的是了解知识广度和记忆情况。

另外,请注意 [[Construct]] 和 [[Call]]。

8.JavaScript 中有哪些不同的函数调用模式? 详细解释。

提示:有四种模式,函数调用,方法调用,.call() 和 .apply()。

9.解释任一即将发布新的 ECMAScript 提案。

提示:比如 2018 的 BigInt,partial 函数,pipeline 操作符 等。

10.JavaScript 中的迭代器(iterators)和迭代(iterables)是什么? 你知道什么是内置迭代器吗?

11.为什么 JavaScript classes(类)被认为是坏的或反模式?

这是一个神话吗?它是否遭受了误传?是否有一些有用的用例?

12.如何在 JSON 中序列化以下对象?

如果我们将以下对象转换为 JSON 字符串,会发生什么?

JavaScript 代码:

const a = {    key1: Symbol(),    key2: 10}// What will happen?console.log(JSON.stringify(a));

登录后复制

13.你熟悉 Typed Arrays 吗? 如果熟悉,请解释他们与 JavaScript 中的传统数组相比的异同?

14. 默认参数是如何工作?

如果我们在调用 makeAPIRequest 函数时必须使用 timeout 的默认值,那么正确的语法是什么?

JavaScript 代码:

function makeAPIRequest(url, timeout = 2000, headers) {       // Some code to fetch data}

登录后复制

15.解释 TCO – 尾调用优化(Tail Call Optimization)。 有没有支持尾调用优化的 JavaScript 引擎?

提示:截至 2018 年,没有。

JavaScript 前端应用设计问题

1.解释单向数据流和双向数据绑定。

Angular 1.x 基于双向数据绑定,而 React,Vue,Elm 等基于单向数据流架构。

2.单向数据流架构在哪些方面适合 MVC?

MVC 拥有大约 50 年的悠久历史,并已演变为 MVP,MVVM 和 MV *。两者之间的相互关系是什么?如果 MVC 是架构模式,那么单向数据流是什么?这些竞争模式是否能解决同样的问题?

3.客户端 MVC 与服务器端或经典 MVC 有何不同?

提示:经典 MVC 是适用于桌面应用程序的 Smalltalk MVC。在 Web 应用中,至少有两个不同的数据 MVC 周期。

4.使函数式编程与面向对象或命令式编程不同的关键因素是什么?

提示:Currying(柯里化),point-free 函数,partial 函数应用,高阶函数,纯函数,独立副作用,record 类型(联合,代数数据类型)等。

5.在 JavaScript 和前端的上下文中,函数式编程与响应式编程有什么关系?

提示:没有正确答案。但粗略地说,函数式编程是关于小型编码,编写纯函数和响应式编程是大型编码,即模块之间的数据流,连接以 FP 风格编写的组件。 FRP – 功能响应式编程( Functional Reactive Programming)是另一个不同但相关的概念。

6.不可变数据结构(immutable data structures)解决了哪些问题?

不可变结构是否有任何性能影响? JS 生态系统中哪些库提供了不可变的数据结构?这些库的优点和缺点是什么?

提示:线程安全(我们真的需要在浏览器 JavaScript 中担心吗?),无副作用的函数,更好的状态管理等。

7.大型应用程序是否应使用静态类型?

如何比较 TypeScript/Flow 与 Elm/ReasonML/PureScript 等 JS 转换语言?这些方法的优缺点是什么?

选择特定类型系统的主要标准应该是什么?

什么是类型推断(type inference)?

静态类型语言和强类型语言有什么区别?在这方面 JavaScript 的本质是什么?

有你知道的弱类型但静态类型的语言吗?有你知道的动态类型但强类型的语言吗?举例一二。

提示:Structural 与 Nominal 类型系统,类型稳健性,工具/生态系统支持,正确性超过方便。

8.JavaScript 中有哪些杰出的模块系统(module systems )?如何评价 ES 模块系统。

列出在实现不同模块系统之间互操作所涉及的一些复杂性问题(主要对 ES 模块和 CommonJS 互操作感兴趣)

9.HTTP/2 将如何影响 JavaScript 应用程序打包?

列出 HTTP/2 与其上一个版本的基本区别。

10.Fetch API 相对于传统的 Ajax 有哪些改进?

使用 Fetch API 有那些缺点/难点吗?

哪些是Ajax 可以做的,而 fetch 不能做的?

11.如何评论 pull-based 和 push-based 的反应系统。

讨论概念,含义,用途等。

在这个讨论中加入惰性和及早求值。

然后在讨论中添加单数和复数值维度。

最后,讨论值解析的同步和异步性质。

为JavaScript中可用的每个组合提供示例。

提示:Observable 是惰性的,基于推送的复数值构造,同时具有 async/sync 调度程序。

12.讨论与 Promise 相关的问题。

提示:及早求值(eager evaluation),尴尬的取消机制,用 then() 方法伪装 map() 和 flatMap() 等。

前端基础和理论问题

1.HTML 中 Doctype 的用途是什么?

具体谈谈,以下每种情况下会发生什么:

Doctype 不存在。

使用了 HTML4 Doctype,但 HTML 页面使用了 HTML5 的标签,如 前端面试题

2、前端面试题

以上就是本篇文章的全部内容,希望能对大家的学习有所帮助。更多精彩内容大家可以关注【创想鸟】相关教程栏目!!!

1.png

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3044319.html

(0)
上一篇 2025年3月13日 15:17:39
下一篇 2025年3月13日 15:17:54

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • TP5实现支付宝电脑网站支付的示例介绍

    本篇文章给大家带来的内容是关于tp5实现支付宝电脑网站支付的示例介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 这两天在公司做一个小型WEB项目,需要有支付功能。第一次做支付宝的支付,踩了点小坑,还算顺利。激动的我赶紧…

    2025年3月13日 编程技术
    200
  • 提高 JavaScript 开发效率的高级 VSCode 扩展之二!

    作为一名业余爱好者、专业人员,甚至是每月只有一次编程的开发人员,你必须知道,对于任何愿意在工作中投入最大生产时间的人来说,拥有智能和敏捷的工具是至关重要的,废话不多说,介绍插件比较重要。 1. Material Theme & Ma…

    2025年3月13日 编程技术
    200
  • 27个适用于JavaScript开发人员的神奇的VSCode工具

    visual studio code(也称为vscode)是一种轻量级但功能强大的跨平台源代码编辑器, 借助对typescript 和chrome调试器等开发工具的内置支持,越来越多的开发都都喜欢使用它。 如果你正在寻找更多的好用的 VSC…

    2025年3月13日 编程技术
    200
  • 2020全新Java面试题——网络(二)

    1、osi 的七层模型都有哪些? 应用层:网络服务与最终用户的一个接口。 (推荐教程:java面试题) 表示层:数据的表示、安全、压缩。 会话层:建立、管理、终止会话。 立即学习“Java免费学习笔记(深入)”; 传输层:定义传输数据的协议…

    2025年3月13日
    200
  • 2020全新Java面试题——Spring(三)

    本文来自java面试题,文中为大家分享了spring相关的面试题,希望可以帮助到大家。1、说一下spring mvc运行流程;2、spring mvc有哪些客户端;3、@RequestMapping的作用是什么。 一、说一下 spring …

    2025年3月13日
    200
  • 详解sublime text3 eslint 安装

    下面由sublime教程栏目给大家详解sublime text3 eslint 安装,希望对需要的朋友有所帮助! 准备工作: sublime text3 编辑器 node环境得支持 ESlint规范  开始安装 以上都安装完毕的时候,那么进…

    2025年3月13日
    200
  • 浅谈VSCode调试js代码的几种方法

    vscode如何调试js代码?下面本篇文章给大家介绍一下vscode调试js代码的几种方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 相关推荐:《vscode》 介绍 VS Code 调试 js 的两种方法: Quo…

    2025年3月13日 编程技术
    200
  • mac下Atom配置js语法校验的方法

    本篇文章给大家介绍一下mac环境中atom配置javascript语法校验的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 相关推荐:《atom》 大家好,这次我带来了Atom的把玩小教程,教你如何配置js语法校验。…

    2025年3月13日
    200
  • 前端有哪些内置对象

    在前端开发中,JavaScript是最常用的编程语言。JavaScript内置对象有Object、Array、String、Number、Boolean、Date、Math、RegExp、Function、Error、JSON、Docume…

    2025年3月13日
    200
  • 15个Vue.js高级面试问题

    本篇文章给大家分享15个vue.js高级面试问题。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 1. 渲染项目列表时,“key” 属性的作用和重要性是什么? 渲染项目列表时,key 属性允许 Vue 跟踪每个 Vnode…

    2025年3月13日
    200

发表回复

登录后才能评论