JS回调函数 callback() ,改变函数this指向call 、apply、bind 的理解

callback() 回调函数

JS是单线程函数,单线程所有的函数执行都是同步的,前一个函数执行完之后再执行下一个函数,这样的话如果排队的函数很多就会造成页面长时间无响应

所以,就要用到了JS异步callback

怎么理解callbck  ?

字面上理解下来就是,回调就是一个函数的调用过程。那么就从理解这个调用过程开始吧。函数a有一个参数,这个参数是个函数b,

当函数a执行完以后执行函数b。那么这个过程就叫回调。

代码如下

//定义主函数,回调函数作为参数
function A(callback) {
    callback();  
    console.log('我是主函数');      
}

//定义回调函数
function B(){
    setTimeout("console.log('我是回调函数')", 3000);//模仿耗时操作  
}

//调用主函数,将函数B传进去
A(B);

//输出结果
我是主函数
我是回调函数

 call 和apply 都可以改变作用域的this 的指向

1、call :语法 call(obj,p1,p2) 

obj 是更改之后 this 指向的对象(必选),p1,p2是原始函数要传的参数(可选)

//在浏览器的window 全局对象添加一个name,在docment对象添加一个name,声明一个对象添加name属性

 

 

 2、apply 和 call一样,也是改变作用域的this 的指向,只是参数传递的方式不一样,apply以数组形式多个传参

输出:Bill Gates,Seatle,USA

 

 3、bind() :将函数绑定到某个对象,bind()会创建一个函数,函数体内的this对象的值会被绑定到传入 bind() 第一个参数的值

 

例1:

 

例2:

 

 

 定义里说了,bind会将函数的this对象的值会被绑定到 bind的第一个参数值,那这里 f 函数里的this对象就指向了{x:1}这个对象

从第二个参数起,会依次传递给原始参数,2就是原始函数的y,函数m(3)中的3就是原始函数的参数z

 二、3者最大区别

  ①、执行方式不同:

    call、apply 都是页面加载之后同步立即执行

    bind() 不会立即执行,而是返回一个新的函数,需要调用执行

  ②、修改this指向性质不同:

    call、apply都是临时修改一次指向,再次调用原函数的时候,原函数的this指向不变。

    bind返回的是一个新的函数,this指向永远指向新的函数。

            

 

     

 

    

 

   

 

 

  ③、传参方式不同(上面有例子)

posted @ 2019-04-08 21:57  尼古拉斯-富贵  阅读(2494)  评论(0编辑  收藏  举报