在面试中,常常会遇到一些手写XXX之类的面试题,因此好好总结一下,对于巩固我们的原生js的基础是非常必要的。

尽管在网上已经有了非常多的总结文章,但在我看来有一个普遍的问题,那就是把原理性的东西过于复杂化了。如果站在面试官的角度,他的目的是在最短的时间内考察出面试者对于JS语言的理解程度,但是在看了网站的诸多总结文章后我发现其中的代码有很大一部分是做意义不大的操作,比如实现一个简单的防抖,只要是核心的流程展示即可,至于其他的一些等模式则没有必要再去深挖,一大堆的if-else让人看上去也眼花缭乱,甚至误导别人直接去背代码,另外,核心的逻辑都能展示出来,再去横向的实现其他的类似情况恐怕也不是什么问题了。

在以下的整理中,建议大家先照的核心要点自己写一遍,然后对照下面的代码,复习效果更好。本文的目的就在于以最简洁的代码帮你从第一性原理的角度理解api的内部运作流程,凡是对于我们理解api没有帮助的的边界情况都不做处理

一、用ES5实现数组的map方法

核心要点:

1.回调函数的参数有哪些,返回值如何处理。

2.不修改原来的数组。



Array



二、用ES5实现数组的reduce方法

核心要点:

1、初始值不传怎么处理

2、回调函数的参数有哪些,返回值如何处理。



Array



三、实现call/apply

思路: 利用this的上下文特性。



//实现apply只要把下一行中的...args换成args即可



四、实现Object.create方法(常用)



function



五、实现bind方法

核心要点:

1.对于普通函数,绑定this指向

2.对于构造函数,要保证原函数的原型对象上的属性不能丢失



Function



大家平时说的手写bind,其实就这么简单:)

六、实现new关键字

核心要点:

  1. 创建一个全新的对象,这个对象的__proto__要指向构造函数的原型对象
  2. 执行构造函数
  3. 返回值为object类型则作为new方法的返回值返回,否则返回上述全新对象
function



七、实现instanceof的作用

核心要点:原型链的向上查找。



function



八、实现单例模式

核心要点: 用闭包和Proxy属性拦截



function



九、实现数组的flat

方式其实很多,之前我做过系统整理,有六种方法,请参考:

需求:多维数组=>一维数组



let



十、实现防抖功能

核心要点:

如果在定时器的时间范围内再次触发,则重新计时。



const



十一、实现节流功能

核心要点:

如果在定时器的时间范围内再次触发,则不予理睬,等当前定时器完成,才能启动下一个定时器。



const



十二、用发布订阅模式实现EventEmit

基于"发布-订阅"的原生JS插件封装中的手写发布订阅部分。

十三、实现深拷贝

以下为简易版深拷贝,没有考虑循环引用的情况和Buffer、Promise、Set、Map的处理,如果一一实现,过于复杂,面试短时间写出来不太现实,如果有兴趣可以去这里深入实现:

深拷贝终极探索。



const



十四、实现Promise

重点难点,比较复杂,请参考我的另一篇步步拆解文章:

我如何实现Promise

十五、使用ES5实现类的继承效果

也是重点知识,我之前做过详细拆解,有五个版本,如果每一版本都能说清楚,能够很好的体现自己对于原型链的理解,

ES5实现继承的那些事
作者:神三元