一道阿里Web前端面试题看出你的JS基本功

开发 前端
学习前端知识是一个漫长且艰辛的过程,我们很多时候被眼前的高楼大厦蒙蔽了双眼,却忽视了作为基础的钢筋水泥。前端框架方兴未艾,说不定过几年又会有新框架取代当下热门的三大框架(vue,react, angular),但是万变不离其宗,只有基础打的牢固,无论这些东西将来怎么改变,你也只会淡然一笑,不过尔尔。
[[350746]]
  1. // 求出如下题目结果 
  2. ({} + {}).length 
  3. ([] + []).length 
  4. (function() {}).length 

这道题目乍一看可能会让你有点懵,你可能会想:一个对象和一个对象相加能得到什么?还能求出其长度?

其实这道题目相当考验了作为一位web前端开发工程师的基本功

在看到这个题目之后,我们首先分析一下情况:

1、({} + {}).length

两个空对象相加,肯定不是数值运算,那么只有可能是字符串连接了,那你可能会得到 “{}{}” 这样的结果,其实不然,因为你忽视了字符串在连接时默认会调用相应的toString()方法

一个空对象调用toString()方法会得到什么?

  1. ({}).toString() 
  2. // "[object Object]" 

得到是 “[object Object]” 这样的字符串,长度为15,那么两个空对象相加之后,其长度则为30

  1. ({} + {}).length 
  2. // 相当于 ({}.toString() + {}.toString()).length 
  3. // 也就是 "[object Object][object Object]",求得这个字符串长度为30 

2、([] + []).length

有了第一道题的经验,那么你可能会这么想:两个空数组相加,一定也是字符串连接,也会调用其toString()方法,最终相当于求 “[object Array][object Array]” 这个字符串的长度,从而得出最终结果28

但是,数组的toString()方法是被重写过的

  1. [1, 2, 3].toString() 
  2. // 得到的是 "1,2,3" 这样由逗号分割元素的字符串 

如果一个空数组调用toString()方法,得到的只会是空字符串“”

所以,这道题的最终结果为0

3、(function() {}).length

有了前两道题目的经验,那你可能会很自然的想到:这里的function也是会调用toString()方法的。如果你这样想,那就是被前两道题目误导了:函数的长度是其形参的个数,所以最终结果是0

总结:学习前端知识是一个漫长且艰辛的过程,我们很多时候被眼前的高楼大厦蒙蔽了双眼,却忽视了作为基础的钢筋水泥。前端框架方兴未艾,说不定过几年又会有新框架取代当下热门的三大框架(vue,react, angular),但是万变不离其宗,只有基础打的牢固,无论这些东西将来怎么改变,你也只会淡然一笑,不过尔尔

 

责任编辑:未丽燕 来源: 今日头条
相关推荐

2024-10-11 17:09:27

2011-05-23 11:27:32

面试题面试java

2022-02-08 18:09:20

JS引擎解析器

2021-10-28 11:40:58

回文链表面试题数据结构

2018-03-06 15:30:47

Java面试题

2023-08-27 15:57:28

前端开发

2009-08-11 10:12:07

C#算法

2023-02-04 18:24:10

SeataJava业务

2009-08-11 14:59:57

一道面试题C#算法

2021-04-13 08:50:21

JS作用域面试题

2021-05-31 07:55:44

smartRepeatJavaScript函数

2020-09-16 14:17:42

flat方法

2009-08-11 15:09:44

一道面试题C#算法

2017-11-21 12:15:27

数据库面试题SQL

2022-04-08 07:52:17

CSS面试题HTML

2023-08-01 08:10:46

内存缓存

2022-01-18 08:16:52

Web 前端JavaScript

2019-09-02 15:06:16

面试字节跳动算法

2021-03-16 05:44:26

JVM面试题运行时数据

2022-07-08 08:21:26

JSbind 方法
点赞
收藏

51CTO技术栈公众号