首页
学习
活动
专区
圈层
工具
发布

JavaScript 回调函数

函数实际上是对象:它们能被“存储”在变量中,能作为函数参数被传递,能在函数中被创建,能从函数中返回; 回调函数 回调函数就是一个参数,将这个函数作为参数传到另一个函数里面,当那个函数执行完之后,再执行传进去的这个函数...这个过程就叫做回调。 回调,回调,不直接调用而是回头调用的意思。主函数的事先干完,回头再调用传进来的那个函数。刚开始看过很多博客,他们总是将回调函数解释的云里雾里,很高深的样子。...function B(){ setTimeout("console.log('我是回调函数')", 3000);//模仿网络请求耗时操作 } //调用主函数,将函数B传进去 A(B);...//输出结果 我是主函数 我是回调函数 上面的代码中,我们先定义了主函数和回调函数,然后再去调用主函数,将回调函数传进去。...看到这里,聪明的你会不会发现ajax的success 不就是一个回调函数吗,我每天都在用ajax,为什么不懂什么是回调呢? 回调就是为了确保在网络请求耗时的情况下保证我们的代码执行有顺序的执行。

3.7K10

js的回调函数详解

什么是回调或者高阶函数 一个回调函数,也被称为高阶函数,是一个被作为参数传递给另一个函数(在这里我们把另一个函数叫做“otherFunction”)的函数,回调函数在otherFunction中被调用。...Rick}); 再一次,注意到我们讲一个匿名函数(没有名字的函数)作为参数传递给了forEach方法。 到目前为止,我们将匿名函数作为参数传递给了另一个函数或方法。...当我们将一个回调函数作为参数传递给另一个函数是,我们仅仅传递了函数定义。我们并没有在参数中执行函数。我们并不传递像我们平时执行函数一样带有一对执行小括号()的函数。...回调函数是闭包 都能够我们将一个毁掉函数作为变量传递给另一个函数时,这个毁掉函数在包含它的函数内的某一点执行,就好像这个回调函数是在包含它的函数中定义的一样。这意味着回调函数本质上是一个闭包。...);}//当我们调用getInput函数时,我们将logStuff作为一个参数传递给它 //因此logStuff将会在getInput函数内被回调(或者执行) getInput({name

7.3K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JavaScript中的回调函数(callback)

    因为function是内置对象,我们可以将它作为参数传递给另一个函数,延迟到函数中执行,甚至执行后将它返回。这是在JavaScript中使用回调函数的精髓。...回调函数被认为是一种高级函数,一种被作为参数传递给另一个函数(在这称作"otherFunction")的高级函数,回调函数会在otherFunction内被调用(或执行)。...当我们作为参数传递一个回调函数给另一个函数时,我们只传递了这个函数的定义,并没有在参数中执行它。 当包含(调用)函数拥有了在参数中定义的回调函数后,它可以在任何时候调用(也就是回调)它。...回调函数的传参 1.将回调函数的参数作为与回调函数同等级的参数进行传递: ? 2.回调函数的参数在调用回调函数内部创建: ?...什么时候用回调函数 1.资源加载:动态加载js文件后执行回调,加载iframe后执行回调,ajax操作回调,图片加载完成执行回调,AJAX等等。

    9.3K10

    JavaScript 高级应用(第二弹)

    用来修改 this 指向的,如果默认值为 null 或者 undefined 的,那么 this 的值就会指向 window(游览器环境下) 调用对象的方法,将另一个对象替换为当前对象。...1.1 call 最实用的 call 的用法,简单来说,我们有个函数,一般都是通过函数名直接调用执行,另一种方式就是通过函数名.call() 来调用 这样做就是改变了函数的上下文,即改变了 this 的指向...,在 bind() 被调用时,这个新函数的 this 指定为 bind() 的第一个参数,而其他参数则作为新函数的参数,供调用使用 一、基本使用 globalThis.x = 9; // Node.js...这里实际上是简写了,使用了 ES6 的箭头函数语法,直接把网络请求拿到的值,当成函数的参数传递给下游处理 一些内置的 JavaScript API 都可以看到 callback 的影子 // 第一个参数就是要处理的函数...这不就告诉了我们这个是怎么用的嘛 翻译过来,简单的说 forEach 函数,会接收三个参数,并且会 告诉 callbackfn 对数组中的每一个元素执行一次回调操作 所以这个 forEach 的案例告诉了我们什么

    85120

    回调、使用Promise封装ajax()、Promise入门

    ---方应杭知乎 callback 是一种特殊的函数,这个函数被作为参数传给另一个函数去调用。这样的函数就是回调函数。...在用户点击 button 时调用的(当用户点击之后,这个函数才执行,现在我只是传了一个参数,这个参数是一个点击后要执行的函数)。...一般来说,只要参数是一个函数,那么这个函数就是回调。 请看我写的封装的简易jQuery.ajax()中的successFN就是一个回调函数....只有在请求成功并接收到响应的时候才会执行这个success函数,这就是回调.传一个函数作为参数但是不执行,让另一个函数去调用,就是回调函数 1.2Callback 有点反直觉 callback 有一点「...代码都在这里 3.1 $.Ajax()中的promise 如果不使用promise,$.ajax请求的时候成功和失败的回调函数是写在参数里的,他是对象参数的一个值 $.ajax({ method

    3.8K51

    javascript异步中的回调

    如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数。...维基百科 在计算机程序设计中,回调函数,或简称回调(Callback 即call then back 被主函数调用运算后会返回主函数),是指通过函数参数传递到其它代码的,某一块可执行代码的引用。...还是回调函数的校验 但我们引用了第三方的插件或库的时候,有时候难免要出现异步回调的情况,一个栗子: xx支付,当用户发起支付后,我们将自己的一个回调函数,传递给xx支付,xx支付比较耗时,执行完之后,理论上它会去执行我们传递给他的回调函数...,是的理论上是这样的,我们把回调的执行权交给了第三方,隐患随之而来 第三方支付,多次调用我们的回调函数怎么办?...第三方支付,不调用我们的回调函数怎么办? 当我们把回调函数的执行权交给别人时,我们也要考虑各种场景可能会发生的问题 总结一下: 回调函数简单方便,但是坑也不少,用的时候需要多注意校验

    3.2K40

    【javascript】异步编年史,从“纯回调”到Promise

    这种控制权的转移, 被叫做“控制反转” 1.调用函数过早 调用函数过早的最值得让人注意的问题, 是你不小心定义了一个函数,使得作为函数参数的回调可能延时调用,也可能立即调用。  ...在1的基础上,我们把这种不确定的情况稍微变得夸张一些: 这个函数中传入的回调, 有99%的几率被异步调用, 有1%的几率被同步调用 在1和2的基础上, 你向一个第三方的函数传了一个回调, 然后在经过了一系列不可描述的...Rejected 而且Promise成功的时候(调用resolve), resolve返回的参数可以被第一个回调接收到, 如上面的value参数 而当Promise失败的时候(调用reject), reject...1.回调过早调用 让我们回到那个回调的痛点:我们有可能会写出一个既可能同步执行, 又可能异步执行的“zalgo”函数。...而如果任意一个数组里的子Promise失败了, 这个“大Promise”的状态会转为Rejected, 并且将错误参数传递给then的第二个回调 竞态 可以用Promise.race方法简单地解决 romise.race

    1.5K80

    ES6中的Promise和Generator详解

    只要p1、p2、p3之中有一个被rejected,p的状态就变成rejected,此时第一个被reject的实例的返回值,会传递给p的回调函数。...那个率先改变的 Promise 实例的返回值,就传递给p的回调函数. Promise.resolve() Promise.resolve()将现有对象转为Promise对象....但是我们如何将这个yield传给result变量呢?要记住yield本身是没有返回值的。 我们需要调用generator的next方法,将异步执行的结果传进去。...“传名调用”(call by name),即直接将表达式x + 5传入函数体,只在用到它的时候求值。 编译器的“传名调用”实现,往往是将参数放到一个临时函数之中,再将这个临时函数传入函数体。...,而是多参数函数,将其替换成一个只接受回调函数作为参数的单参数函数。

    1.6K21

    JavaScript系列之回调函数callback

    解释得很明确,回调函数就是作为参数传递给另一个函数并在其父函数完成后执行的函数。 听起来似乎有点不好理解,所以还是举例进行说明,介绍回调函数之前先简单说明一下同步和异步,前端也有同步和异步。...同步和异步总得来说,两者最明显的区别就是是否需要等待,如果是串行执行的就是同步机制,是并行执行的就是异步机制,这个比较好理解 回调函数的使用并没有同步和异步的区别,回调函数只是一种特殊的函数,可以应用于同步调用场景...,也可以应用于异步调用场景 异步请求中的回调函数 最常用的有ajax异步调用或者事件机制,例子: $.get('${root}/saveOrUpdate.do',function(result){...alert(result); }); 同步请求中的回调函数 业务场景:举个例子,点击按钮会触发main函数,进行接口数据保存(异步方式),数据保存成功之后,再回调打开弹窗的函数 保存数据函数:...,callbackFunction); } 回调函数,数据保存成功后再调用 /*保存时的回调函数*/ function callbackFunction(saveSuccess){

    1.1K20

    前端基础进阶(十五):详解 Promise对象

    从前面几篇文中的知识我们可以得知,想要确保某代码在谁谁之后执行,我们可以利用函数调用栈,将想要执行的代码放入回调函数中。...resolve函数的作用是,将Promise对象的状态从“未完成”变为“成功”(即从 pending 变为 resolved),在异步操作成功时调用,并将异步操作的结果,作为参数传递出去;reject函数的作用是...需要注意的是,在getJSON内部,resolve函数和reject函数调用时,都带有参数。 如果调用resolve函数和reject函数时带有参数,那么它们的参数会被传递给回调函数。...第一个回调函数完成以后,会将返回结果作为参数,传入第二个回调函数。 采用链式的then,可以指定一组按照次序调用的回调函数。...该实例执行完catch方法后,也会变成resolved,导致Promise.all()方法参数里面的两个实例都会resolved,因此会调用then方法指定的回调函数,而不会调用catch方法指定的回调函数

    1.5K20

    前端基础进阶(十五):详解 Promise对象

    从前面几篇文中的知识我们可以得知,想要确保某代码在谁谁之后执行,我们可以利用函数调用栈,将想要执行的代码放入回调函数中。...resolve函数的作用是,将Promise对象的状态从“未完成”变为“成功”(即从 pending 变为 resolved),在异步操作成功时调用,并将异步操作的结果,作为参数传递出去;reject函数的作用是...需要注意的是,在getJSON内部,resolve函数和reject函数调用时,都带有参数。 如果调用resolve函数和reject函数时带有参数,那么它们的参数会被传递给回调函数。...第一个回调函数完成以后,会将返回结果作为参数,传入第二个回调函数。 采用链式的then,可以指定一组按照次序调用的回调函数。...该实例执行完catch方法后,也会变成resolved,导致Promise.all()方法参数里面的两个实例都会resolved,因此会调用then方法指定的回调函数,而不会调用catch方法指定的回调函数

    78920

    ES6之Promise

    基本语法 Promise 就是为了解决“回调地狱”问题的,它可以将异步操作的处理变得很优雅。...回调地狱,代码难以维护, 常常第一个的函数的输出是第二个函数的输入这种现象promise可以支持多个并发的请求,获取并发请求中的数据这个promise可以解决异步的问题,本身不能说promise是异步的...{ resolve(value) } else { reject(error) } }) 复制代码 - Promise构造函数接受一个函数作为参数,该函数的两个参数分别是...- 处理结果正常的话,调用resolve(处理结果值),将Promise对象的状态从“未完成”变为“成功”(即从 pending 变为 resolved),在异步操作成功时调用,并将异步操作的结果,作为参数传递出去...- 处理结果错误的话,调用reject(Error对象),将Promise对象的状态从“未完成”变为“失败”(即从 pending 变为 rejected),在异步操作失败时调用,并将异步操作报出的错误

    98420

    你真的懂异步编程吗?

    ,异步执行的最终结果,依然需要回到 JS 线程上进行处理,在JS中,异步的结果 回到 JS 主线程 的方式采用的是 “ 回调函数 ” 的形式 , 所谓的 回调函数 就是在 JS 主线程上声明一个函数,然后将函数作为参数传入异步调用线程...,当异步执行结束后,调用这个函数,将结果以实参的形式传入函数的调用(也有可能不传参,但是函数调用一定会有),前面代码中 setTimeout 就是一个异步方法,传入的第一个参数就是 回调函数,这个函数的执行就是消息队列中的...“回调”; 下面我们自己封装一个 ajax 请求,来进一步说明回调函数与异步的关系 Ajax 的异步请求封装 function myAjax(url,callback) { var xhr =...函数调用结束后,ajax 的网络请求却依然在进行着,如果想要获取到 ajax 网络请求的结果,我们就需要在结果返回后,调用一个 JS 线程的函数,将结果以实参的形式传入: myAjax('....,会调用成功的回调函数 onFulfilled 来将异步结果返回;异步执行成功的状态是 Rejected, 这就是承诺给你的结果,然后调用 onRejected 说明失败的原因(异常接管); 将前面对

    1.1K30

    Jquery Ajax请求文件下载操作失败的原因分析及解决办法

    有效值如下: xml-响应文本被解析为XML文档,而作为结果的XML DOM被传递给回调函数 html-响应文本未经处理就被传递给回调函数。...) script-响应文本被传递给回调函数。...如果省略这个属性,则不对响应文本进行任何处理或求值就传递给回调函数 timeout 数值 设置Ajax请求的超时值(毫秒)。...如果请求在超时值到期之前仍未完成,则中止请求并且调用错误回调函数(如果已定义) global 布尔型 启用或禁用全局函数的触发。这些函数可以附加到元素上,并且在Ajax调用的不同时刻或状态下触发。...第二个参数是包含状态码的字符串—这种情况下永远为成功状态码 error 函数 如果请求的响应返回错误状态码,则这个函数被调用。

    4.4K30

    Promise、Generator、Async 合集

    异步解决方案的发展历程1.回调函数从早期的Javascript代码来看,在ES6诞生之前,基本上所有的异步处理都是基于回调函数函数实现的,你们可能会见过下面这种代码:ajax('aaa', () =>...它就是为了解决回调函数产生的问题而诞生的。有了Promise对象,就可以将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数。此外,Promise对象提供统一的接口,使得控制异步操作更加容易。...return ajax('ccc')})通过使用Promise来处理异步,比以往的回调函数看起来更加清晰了,解决了回调地狱的问题,Promise的then的链式调用更能让人接受,也符合我们同步的思想。...then中回调的内容异步中先执行微任务,再执行宏任务Promise 相关问题Promise中的then第二个参数和catch有什么区别?...Promise.race(iterable) 当iterable参数里的任意一个子promise被成功或失败后,父promise马上也会用子promise的成功返回值或失败详情作为参数调用父promise

    48000

    Ajax向服务器端发送请求

    Ajax是一种异步进程,程序不会等待异步代码执行完后再继续执行后续代码 当后续代码需要调用Ajax返回的数据时,可能会有数据未返回的问题 Ajax的实现步骤 创建Ajax对象 var xhr =...状态值 在Ajax请求执行的过程中每一步都对应一个状态码 数值 意义 0 请求没有初始化,没有调用 open() 1 请求已经建立,但是没有发送 send() 2 请求已经发送 3 请求正在处理,通常响应中已经有部分数据可以使用了...responseText = JSON.parse(responseText); } // 如果请求成功 if (xhr.status == 200) { // 调用成功回调函数, 并且将服务器端返回的结果传递给成功回调函数...defaults.success(responseText, xhr); } else { // 调用失败回调函数并且将xhr对象传递给回调函数 defaults.error(responseText..., xhr); } } // 当网络中断时 xhr.onerror = function () { // 调用失败回调函数并且将xhr对象传递给回调函数 defaults.error

    3.1K20
    领券