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属性

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

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

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

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

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

输出:Bill Gates,Seatle,USA

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

 

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

 

例1:

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

 

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

例2:

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

 

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

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

 

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-10-16
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-10-29
  • 2022-12-23
  • 2022-12-23
  • 2019-09-24
  • 2023-02-24
  • 2021-12-06
  • 2021-05-09
相关资源
相似解决方案