当前栏目
一道阿里Web前端面试题看出你的JS基本功
![一道阿里web前端面试题看出你的JS基本功](https://s6.51cto.com/oss/202011/06/39cbe1d2818479fd3424d1efff4c3758.jpeg)
- // 求出如下题目结果
- ({} + {}).length
- ([] + []).length
- (function() {}).length
这道题目乍一看可能会让你有点懵,你可能会想:一个对象和一个对象相加能得到什么?还能求出其长度?
其实这道题目相当考验了作为一位web前端开发工程师的基本功
在看到这个题目之后,我们首先分析一下情况:
1、({} + {}).length
两个空对象相加,肯定不是数值运算,那么只有可能是字符串连接了,那你可能会得到 “{}{}” 这样的结果,其实不然,因为你忽视了字符串在连接时默认会调用相应的toString()方法
一个空对象调用toString()方法会得到什么?
- ({}).toString()
- // "[object Object]"
得到是 “[object Object]” 这样的字符串,长度为15,那么两个空对象相加之后,其长度则为30
- ({} + {}).length
- // 相当于 ({}.toString() + {}.toString()).length
- // 也就是 "[object Object][object Object]",求得这个字符串长度为30
2、([] + []).length
有了第一道题的经验,那么你可能会这么想:两个空数组相加,一定也是字符串连接,也会调用其toString()方法,最终相当于求 “[object Array][object Array]” 这个字符串的长度,从而得出最终结果28
但是,数组的toString()方法是被重写过的
- [1, 2, 3].toString()
- // 得到的是 "1,2,3" 这样由逗号分割元素的字符串
如果一个空数组调用toString()方法,得到的只会是空字符串“”
所以,这道题的最终结果为0
3、(function() {}).length
有了前两道题目的经验,那你可能会很自然的想到:这里的function也是会调用toString()方法的。如果你这样想,那就是被前两道题目误导了:函数的长度是其形参的个数,所以最终结果是0
总结:学习前端知识是一个漫长且艰辛的过程,我们很多时候被眼前的高楼大厦蒙蔽了双眼,却忽视了作为基础的钢筋水泥。前端框架方兴未艾,说不定过几年又会有新框架取代当下热门的三大框架(vue,react, angular),但是万变不离其宗,只有基础打的牢固,无论这些东西将来怎么改变,你也只会淡然一笑,不过尔尔
相关文章
- 鲜为人知但很有用的 HTML 属性
- 翻转再翻转!有意思的水平横向溢出滚动
- 自定义计数器小技巧!CSS 实现长按点赞累加动画
- 过五关!React高频面试题指南
- 软件开发中的十个认知偏差
- 不需要 JS!仅用 CSS 也能达到监听页面滚动的效果!
- 一文读懂TypeScript类型兼容性
- Vue 的响应式原则与双向数据绑定
- 快速掌握 TypeScript 新语法:Infer Extends
- JWT教你如何证明你是我的人!
- 一篇带给你 V8 GC 的实现
- 面试官:请使用JS完成一个LRU缓存?
- 通过可视化来学习JavaScript事件循环
- 新的跨域策略:使用 COOP、COEP 为浏览器创建更安全的环境
- 为什么有人说 vite 快,有人却说 vite 慢?
- 种草 Vue3 中几个好玩的插件和配置
- 超全面的前端工程化配置指南
- Vue 状态管理未来样子
- Volatile关键字能保证原子性么?
- 面试突击:SpringBoot 有几种读取配置文件的方法?