jQuery 中提供了一个Callback的工具类Callbacks,它提供了一个Callback Chain。使用它可以在一个chain上来执行相关操作。它也是jQuery中的ajax, Deferred的基础。我们也可以使用它来构建需要异步执行的组件等。

Callbacks API说明

构造器

jQuery.Callbacks(flags) 创建Callbacks对象。

Callbacks对象里包含了一个callback function的数组(也称为 callback chain)。

method说明

add(function|functions) : 将一个或多个funcation作为一个callback function 添加到callback chain中。

remove(function|functions) :从callback chain中移除指定的callback function。

fire(arguments):触发callback chain。在执行chain中的每一个callbakc function时,参数都是一样的。

fireWith(context,arguments): 在context下执行callback chain。

disable(): 禁用Callbacks。其实是将chain设置为undefined。所以在禁用后,add()是添加不成功的,那么fire时也就不会有什么操作了。

empty():只是将chain内容清空。

构造器参数

flags:

·unique chain中的funcation是不能重复的。如果重复添加时,是添加不了的。生效于添加阶段(也就是在add函数中使用)。

·once 是整个链中的每一个callback function都要被执行一次,并且只执行一次。

·memory 保留上一次fire时的参数,并记录上一次fire时执行到第n个callback function。在下一次fire时,先将上一次未执行的(包括上一次之后,又新加的callback)执行完毕,然后才开启新一轮执行。

·stopOnFalse 执行一个callback时判断执行结果是否为false,如果是false的话就停止不在执行。

重要流程

Add一个函数的流程

1)如果有unique标志,判断要添加的是否存在,只在不存在时添加到chain中。

2)如果没有unique标志,代表可以重复。直接添加到chain中。

Fire的流程:

1)设置context

如果没有指定context,那么context值是 Callbacks对象。

2)将chain中未执行的functions执行一遍。在此过程中,每执行完一个就会基于stopOnFalse来进行判断(如果设置的话)

3)后置处理

  如果Callbacks可以多次执行:

  如果还有没有执行的参数,再次执行。

  否则:(只能执行一次)

    如果被stopOnFalse了,执行disable()。

  否则:执行empty

Demo

<script src="https://code.jquery.com/jquery-1.7.2.js" integrity="sha256-FxfqH96M63WENBok78hchTCDxmChGFlo+/lFIPcZPeI="   crossorigin="anonymous"></script>

<script type="text/javascript">

$(function(){

function fn1(value){

console.log(arguments.length,value);

}

function fn2(value){

return "fn2, " + value;

}

function fn3(value){

fn1(fn2(value));

}

debugger;

var callbacks = jQuery.Callbacks("once memory");

callbacks.add(fn1,fn2,fn3);

callbacks.fire("hello_0")

console.log("--------1-------")

callbacks.add([fn1,fn3]);

callbacks.add(fn2);

callbacks.add(fn3);

callbacks.fire("hello_1");

});

</script>

jQuery: Callbacks的更多相关文章

  1. jQuery.Callbacks之demo

    jQuery.Callbacks是jquery在1.7版本之后加入的,是从1.6版中的_Deferred对象中抽离的,主要用来进行函数队列的add.remove.fire.lock等操作,并提供onc ...

  2. jQuery回调、递延对象总结(上篇)—— jQuery.Callbacks

    前言: 作为参数传递给另一个函数执行的函数我们称为回调函数,那么该回调又是否是异步的呢,何谓异步,如:作为事件处理器,或作为参数传递给 (setTimeout,setInterval)这样的异步函数, ...

  3. jQuery.Callbacks 源码解读二

    一.参数标记 /* * once: 确保回调列表仅只fire一次 * unique: 在执行add操作中,确保回调列表中不存在重复的回调 * stopOnFalse: 当执行回调返回值为false,则 ...

  4. jQuery源代码学习之四——jQuery.callbacks

    自己实现的callbacks模块相较于jquery源代码中的callbacks模块有所简化,表面上看没有考虑firing这个参数,没有对之进行任何处理,即没有考虑在函数执行过程中,再次调用add,re ...

  5. jQuery.Callbacks之源码解读

    在上一篇jQuery.Callbacks之demo主要说了Callbacks对象初始化常见的选项,这一篇主要分析下Callbacks对象的源代码,对给出两个较为繁琐的demo // String to ...

  6. jQuery回调、递延对象总结(一)jQuery.Callbacks详解

    前言: 作为参数传递给另一个函数执行的函数我们称为回调函数,那么该回调又是否是异步的呢,何谓异步,如:作为事件处理器,或作为参数传递给 (setTimeout,setInterval)这样的异步函数, ...

  7. jQuery.callbacks 注释

    (function( jQuery ) { // String to Object flags format cache var flagsCache = {}; // Convert String- ...

  8. jquery.Callbacks的实现

    前言 本人是一个热爱前端的菜鸟,一直喜欢学习js原生,对于jq这种js库,比较喜欢理解他的实现,虽然自己能力有限,水平很低,但是勉勉强强也算是能够懂一点吧,对于jq源码解读系列,博客园里有很多,推荐大 ...

  9. jQuery 2.0.3 源码分析 回调对象 - Callbacks

    源码API:http://api.jquery.com/jQuery.Callbacks/ jQuery.Callbacks()是在版本1.7中新加入的.它是一个多用途的回调函数列表对象,提供了一种强 ...

随机推荐

  1. hdu 6096---String(AC自动机)

    题目链接 Problem Description Bob has a dictionary with N words in it.Now there is a list of words in whi ...

  2. oracle语句批处理

    数据量有40万条,从一个对象table_01一条一条取数到对象table_02,如果用原始的 Statement Statmt =comm.createStatement(); String sql= ...

  3. [js高手之路]node js系列课程-图解express+supervisor+ejs用法

    上文通过node js自带的http模块搭建了一个简易的服务器,实际在开发中,一般用的是express框架,本文我们就来讲讲项目开发中必备不可少的几样东西: 服务器( express ) 路由( ex ...

  4. Oracle实现分页查询的SQL语法汇总

    1.无ORDER BY排序的写法.(效率最高) 经过测试,此方法成本最低,只嵌套一层,速度最快!即使查询的数据量再大,也几乎不受影响,速度依然! sql语句如下: ) TABLE_ALIAS ; 2. ...

  5. Java中 Comparator接口 与Comparable 的区别

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt159 comparator接口与Comparable接口的区别 1. Com ...

  6. 理解oracle中连接和会话

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp44 理解oracle中连接和会话 1.  概念不同:概念不同: 连接是指物 ...

  7. webarchive文件转换成htm文…

    原文地址:webarchive文件转换成htm文件作者:xhbaxf Mac OS X系统带有文件转换功能,可以把webarchive文件变成html文件.方法是:   Step 1: 建立一个文件夹 ...

  8. MVC 常用扩展点:过滤器、模型绑定等

    MVC 常用扩展点:过滤器.模型绑定等 一.过滤器(Filter) ASP.NET MVC中的每一个请求,都会分配给对应Controller(以下简称"控制器")下的特定Actio ...

  9. 团队作业8——第二次项目冲刺(Beta阶段)--5.25 5th day

    团队作业8--第二次项目冲刺(Beta阶段)--5.25 fifth day Day five: 会议照片 项目进展 Beta冲刺的第四天,以下是今天具体任务安排: 队员 昨天已完成的任务 今日计划完 ...

  10. 201521123122 《java程序设计》第八周实验总结

    201521123122 <java程序设计>第八周实验总结 1. 本周学习总结 以你喜欢的方式(思维导图或其他)归纳总结集合相关内容. 2. 书面作业 List中指定元素的删除(题目4- ...