关于原生js中bind函数的简单实现

JavaScript023

关于原生js中bind函数的简单实现,第1张

今天继续研究了bind函数的实现,也知道了shim和polyfill的说法,现在总结一下,

if

(!Function.prototype.bind)

{

Function.prototype.bind

=

function

(oThis)

{

if

(typeof

this

!==

"function")

{

//

closest

thing

possible

to

the

ECMAScript

5

internal

IsCallable

function

throw

new

TypeError("Function.prototype.bind

-

what

is

trying

to

be

bound

is

not

callable")

}

var

aArgs

=

Array.prototype.slice.call(arguments,

1),

fToBind

=

this,

fNOP

=

function

()

{},

fBound

=

function

()

{

return

fToBind.apply(this

instanceof

fNOP

&&

oThis

?

this

:

oThis

||

window,

aArgs.concat(Array.prototype.slice.call(arguments)))

}

fNOP.prototype

=

this.prototype

fBound.prototype

=

new

fNOP()

return

fBound

}

}

这是官方文档上的实现,我分二个方面来谈我要说的东西,

第一个是参数,agruments的使用

var

aArgs

=

Array.prototype.slice.call(arguments,

1),这里是将bind函数的参数数组取出来,第一个参数不要(就是不要oThis)也就是要被绑定方法的那个对象,第二个是

aArgs.concat(Array.prototype.slice.call(arguments)))

这里是用了数组的方法,把参数插在参数数组后面,要注意,这个函数是要被return

出去然后执行的,他的参数数组是return出去的那个fBound函数的参数数组,所以上下两个参数数组是不一样的,有点像柯里化。

第二个是上下文,在其中上下文的变化比较难理解,bind函数主要就是为了绑定上下文来使用的

fToBind

=

this

这里是保存了对象的上下文,紧接着下面的apply方法让要被绑定的那个对象可以使用该上下文

fNOP.prototype

=

this.prototype

fBound.prototype

=

new

fNOP()

这里是以fNOP为中介把this.prototype这个原对象的属性给fBound,确保fBound是在定义的时候的那个上下文里面执行。本来

bound.prototype

=

self.prototype就可以将原属性集成过来了,但是这样两个对象属性都指向同一个地方,修改

bound.prototype

将会造成self.prototype

也发生改变,这样并不是我们的本意。所以通过一个空函数

nop

做中转,能有效的防止这种情况的发生。

以上这篇关于原生js中bind函数的简单实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

fun.bind(this,arg1,arg2,...)

bind()方法会创建一个新的函数,称为绑定函数,fun方法在this环境下调用

该方法可传入两个参数,第一个参数作为this,第二个及以后的参数则作为函数的参数调用

传参方式:

一个最简单的bind,每个function都有bind索要应该是一个Function的原型方法

先看一个 bind 函数的例子:

如果我们要手写一个 bind 函数的话,我们需要知道 bind 拿了什么参数,干了什么:①接收一个对象(this);②接受n个参数;③返回函数。

那么需求我们知道了,如何实现呢?

首先 fn1 对于 Function 来说是 Function 的实例,这个没有问题吧。那么肯定有 fn1.__proto__ === Function.prototype 。 Function.prototype 中是有 call 、 apply 等函数的API,既然这样我们就用我们原型 Function 的方法~

我们不确定bind的参数传几个,我们所知道的只是第一个参数是 this 要指的对象,第二个一直到最后一个参数我们都不确定,所以我们在手写的时候没法一个一个接收参数,所以第一步我们要将第一个参数 this 对象和后面的参数分离。

下面是步骤:

其中, slice 是 Array.prototype 上的方法,这块可以理解为将 arguments 这个类数组赋予数组的 slice 功能。

用 shift 方法将数组的第一项从数组中剔除,改变了原数组,返回了被剔除的这个数组~ 好,这下第一个参数有啦

为了方便,好看,把 this 赋值给变量 self 。这块的 this 就是指:谁调用的这个 bind1 ,就指向谁,比如一开始咱们的例子,如果 fn1 执行的话,就指向 fn1 。

结果我们是要输出绑定过的 this 函数,所以我们这里用 apply 方法,将之前获取的第一个this对象参数 t ,和后面的n个参数 args 传递进去,就是我们想要的结果啦。

检验一下:

bind函数需要再次调用