【面试题】 经典但依然超难做的 前端面试题 (值得收藏)

简介: 【面试题】 经典但依然超难做的 前端面试题 (值得收藏)

给大家推荐一个实用面试题库

1、前端面试题库 (面试必备)            推荐:★★★★★

地址:前端面试题库

最近我的一些学员比较膨胀,认为已经精通了 HTML、CSS、JavaScript 三剑客,老是催我进入框架学习和项目实战。

为了让他们意识到自身的不足,我搬出了几道经典前端面试题,毫无例外,全员覆灭。

1. a 应该等于什么可以让下面的 console.log 输出 true?

const a = void 0;
console.log(a == 1 && a == 2 && a == 3);// true

2. 实现 sum 函数,参数为数组,求该数组所有项之和,不允许使用循环和数组方法

const arr = [1, 2, 3, 4, 5]
function sum (arr) {
  // TODO:
}
sum(arr);// 15

3.请说出如下代码的输出

var x;
let y;
var z;
if(true) {
  let z;
  x();
  console.log(z);
  x = 1;
  function x(z) {
    z = 4;
  }
  function y(z) {
    z = 3;
  }
  z = () => {}
  y(z);
  console.log(z);
  x = 2;
  console.log(x);
}
console.log(x);
console.log(y);
console.log(z);

题解

1

这一题是在考察隐式类型转换

当两个类型不一样的变量进行双等于比较时,会调用它的 valueOf 方法,并使用 valueOf 方法返回的值进行比较。

我们只需要定义一个初始为 1 的属性,每次调用时让它增加 1 就可以了。

var a = {
  n: 1,
  valueOf() {
    return this.n++;
  }
}

2

这一题是在考察递归。

遍历一个数组中的所有子项,能用到的方法只有循环和递归。

首选需要分析递归公式。

假设有个内部函数 _sum,该函数接受 i 作为参数,可以计算出从数组第 i 位到数组末尾之和。

基于这个函数,我们还可以推演出一个递推公式:_sum(i) = arr[i] + _sum(i + 1)。

最后再来分析边缘情况,当参数 i 大于等于数组的 length 之后,就无法求和了,所以这时返回 0。

function sum(arr) {
  function _sum(i) {
    if(i >= arr.length) return 0
    return arr[i] + _sum(++i)
  }
  return _sum(0)
}

3

这一题是在考察作用域。

但是题出得确实有点丧心病狂。

第 8 行输出 undefined。这个比较简单,因为调用 x 时没有传递参数,所以 x 函数中改变的 z 是 x 的参数,和外层的 z 无关。

第 18 行输出 ()=>{}。因为 15 行将 z 设置成了箭头函数,16 行调用了 y,但是在 y 中修改的是函数作用域内的参数,而不是外层的 z。

第 20 行输出 2,毫无疑问。

第 23 行输出 1,这就有点难以理解了。第 9 行代码会把外层的 x 设置为 1,但是第 10 行代码会在 if 块级作用域中创建一个函数 x。在此之后 x 的访问,都是在访问块级作用域中的 x,和外部的 x 无关。

第 24 行输出 undefined,因为外层的 y 是通过 let 声明,会形成块级作用域,if 中的函数 y 不会提升。

第 25 行输出 undefined,因为 if 块中有使用 let 声明 z,所以 z 存在块级作用域,不会起到变量提升的效果。

说实话这些题目看上去头很刁难人,但确实又是在考察基础的编程语言能力。不乏一些老手程序员也在这些「初级面试题」上面翻了跟头。

你答对了几道题呢?

 

给大家推荐一个实用面试题库

1、前端面试题库 (面试必备)            推荐:★★★★★

地址:前端面试题库

相关文章
|
28天前
|
缓存 前端开发 JavaScript
"面试通关秘籍:深度解析浏览器面试必考问题,从重绘回流到事件委托,让你一举拿下前端 Offer!"
【10月更文挑战第23天】在前端开发面试中,浏览器相关知识是必考内容。本文总结了四个常见问题:浏览器渲染机制、重绘与回流、性能优化及事件委托。通过具体示例和对比分析,帮助求职者更好地理解和准备面试。掌握这些知识点,有助于提升面试表现和实际工作能力。
62 1
|
3月前
|
Web App开发 前端开发 Linux
「offer来了」浅谈前端面试中开发环境常考知识点
该文章归纳了前端开发环境中常见的面试知识点,特别是围绕Git的使用进行了详细介绍,包括Git的基本概念、常用命令以及在团队协作中的最佳实践,同时还涉及了Chrome调试工具和Linux命令行的基础操作。
「offer来了」浅谈前端面试中开发环境常考知识点
|
2月前
|
Web App开发 JavaScript 前端开发
前端Node.js面试题
前端Node.js面试题
|
4月前
|
存储 前端开发 JavaScript
44 个 React 前端面试问题
【8月更文挑战第18天】
52 2
|
4月前
|
存储 JavaScript 前端开发
2022年前端js面试题
2022年前端js面试题
40 0
|
4月前
|
存储 前端开发 JavaScript
44 个 React 前端面试问题
44 个 React 前端面试问题
|
4月前
|
前端开发 应用服务中间件 API
"揭秘!面试官必问:你是如何巧妙绕过跨域难题的?前端代理VS服务器端CORS,哪个才是你的秘密武器?"
【8月更文挑战第21天】在软件开发中,尤其前后端分离架构下,跨域资源共享(CORS)是常见的挑战。主要解决方案有两种:一是服务器端配置CORS策略,通过设置响应头控制跨域访问权限,无需改动前端代码,增强安全性;二是前端代理转发,如使用Nginx或Webpack DevServer在开发环境中转发请求绕过同源策略,简化开发流程但不适用于生产环境。生产环境下应采用服务器端CORS策略以确保安全稳定。
53 0
|
4月前
|
存储 Java
【IO面试题 四】、介绍一下Java的序列化与反序列化
Java的序列化与反序列化允许对象通过实现Serializable接口转换成字节序列并存储或传输,之后可以通过ObjectInputStream和ObjectOutputStream的方法将这些字节序列恢复成对象。
|
17天前
|
存储 算法 Java
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
本文详解自旋锁的概念、优缺点、使用场景及Java实现。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
|
19天前
|
存储 缓存 Java
大厂面试必看!Java基本数据类型和包装类的那些坑
本文介绍了Java中的基本数据类型和包装类,包括整数类型、浮点数类型、字符类型和布尔类型。详细讲解了每种类型的特性和应用场景,并探讨了包装类的引入原因、装箱与拆箱机制以及缓存机制。最后总结了面试中常见的相关考点,帮助读者更好地理解和应对面试中的问题。
41 4
下一篇
无影云桌面