1. <script language="javascript" type="text/javascript">
  2. function doSomething(callback) {
  3. // …
  4. // Call the callback
  5. callback('stuff', 'goes', 'here'); // 给callback赋值,callback是个函数变量
  6. }
  7.  
  8. function foo1(a, b, c) {
  9. // I'm the callback
  10. alert(a + " " + b + " " + c);
  11. }
  12. doSomething(foo1); // foo1函数将使用callback函数中的数据 stuff goes here
  13.  
  14. var foo2 = function(a,b,c) {
  15. // I'm the callback
  16. alert(a + " " + b + " " + c);
  17. }
  18. doSomething(foo2); // foo2函数将使用callback函数中的数据 stuff goes here
  19.  
  20. doSomething(function(a,b,c){
  21. alert(a + " " + b + " " + c); // function函数将使用callback函数中的数据 stuff goes here
  22. });
  23. </script>

callback这个参数必须是函数才有效。才能起到回调的作用。

  1. <script language="javascript" type="text/javascript">
  2. function doSomething(callback) {
  3. // …
  4. // Call the callback
  5. if(typeof callback === 'function'){
  6. callback('stuff', 'goes', 'here'); // 给callback赋值,callback是个函数变量
  7. }else{
  8. alert('fuck you');
  9. }
  10. }
  11.  
  12. function foo1(a, b, c) {
  13. // I'm the callback
  14. alert(a + " " + b + " " + c);
  15. }
  16. doSomething(foo1); // foo1函数将使用callback函数中的数据 stuff goes here
  17.  
  18. var foo2 = function(a,b,c) {
  19. // I'm the callback
  20. alert(a + " " + b + " " + c);
  21. }
  22. doSomething(foo2); // foo2函数将使用callback函数中的数据 stuff goes here
  23.  
  24. doSomething(function(a,b,c){
  25. alert(a + " " + b + " " + c); // function函数将使用callback函数中的数据 stuff goes here
  26. });
  27. var foo3 = 'a';
  28. doSomething(foo3);
  29. </script>

foo3不是函数的时候,弹出fuck you

jQuery实例

原函数

  1. $.fn.citySelect=function(settings)

添加回调

  1. $.fn.citySelect=function(settings, changeHandle) // 添加回调函数changeHandle

给回调函数赋值

  1. //选项变动赋值事件
  2. var selectChange = function (areaType) {
  3. if(typeof changeHandle === 'function'){ // 判断callback是否是函数
  4. var prov_id = prov_obj.get(0).selectedIndex;
  5. var city_id = city_obj.get(0).selectedIndex;
  6. var dist_id = dist_obj.get(0).selectedIndex;
  7.  
  8. if(!settings.required){
  9. prov_id--;
  10. city_id--;
  11. dist_id--;
  12. };
  13.  
  14. if(dist_id<0){
  15. var data = {
  16. prov: city_json.citylist[prov_id].p,
  17. city: city_json.citylist[prov_id].c[city_id].n,
  18. dist: null
  19. };
  20. }else{
  21. var data = {
  22. prov: city_json.citylist[prov_id].p,
  23. city: city_json.citylist[prov_id].c[city_id].n,
  24. dist: city_json.citylist[prov_id].c[city_id].a[dist_id].s
  25. };
  26. }
  27.  
  28. changeHandle(data, areaType); // 返回两个处理好的数据
  29. }
  30. };

获取省市县数据data以及触发的change事件类型areaType

  1. // 选择省份时发生事件
  2. prov_obj.bind("change",function(){
  3. cityStart();
  4. selectChange('prov'); // 返回数据
  5. });
  6.  
  7. // 选择市级时发生事件
  8. city_obj.bind("change",function(){
  9. distStart();
  10. selectChange('city'); // 返回数据
  11. });
  12.  
  13. // 选择区级时发生事件
  14. dist_obj.bind("change",function(){
  15. selectChange('dist'); // 返回数据
  16. });

在各个事件中执行

前端使用

  1. $("#s_city").citySelect({
  2. prov: "江苏省",
  3. city: "宿迁市",
  4. dist: "宿城区",
  5. nodata: "none"
  6. },
  7. function(data, type) {
  8. selectAgent(data.city, data.dist);
  9. });

使用回调回来的data数据,用于selectAgent函数中

  1. function selectAgent(city,district){
  2. $.ajax({
  3. type:"POST",
  4. url:"{sh::U('Index/ajax',array('todo'=>'getagent'))}",
  5. data:"city="+city+"&district="+district,
  6. success:function(json){
  7. json = JSON.parse(json);
  8. opt_str = "<option value=''>-请选择-</option>"
  9. if(json.status == 1){
  10. $.each(json.data,function(index,con){
  11. opt_str += "<option value="+con.id+">"+con.name+" 电话:"+con.tel+"</option>"
  12. })
  13. }
  14. $('#agent_id').html(opt_str);
  15. }
  16. });
  17. }

去ajax获取相应的代理商数据。

改造插件完成。

jQuery改造插件,添加回调函数的更多相关文章

  1. jquery Ajax 不执行回调函数success的原因

    jquery Ajax 不执行回调函数success的原因: $.ajax({ type: "post", contentType: "application/json& ...

  2. jQuery编写插件--封装全局函数的插件(一些常用的js验证表达式)

    上一篇写到了jQuery插件的3种类型,介绍了第一种类型的写法--封装jQuery对象的方法插件.这一篇要介绍第二种插件类型:封装全局函数的插件:这类插件就是在jQuery命名空间内部添加函数:这类插 ...

  3. javascript与jQuery的each,map回调函数参数顺序问题

    <script> var arr = [2,3,6,7,9]; //javascript中的forEach 和 map方法 arr.forEach(function(value,index ...

  4. jQuery hide() 参数callback回调函数执行问题

    $("#b").click(function() { $("div").hide(1000,bbb); //-------------1 bbb是一个函数,但这 ...

  5. jQuery扩展插件和拓展函数的写法

    <script type="text/JavaScript">            //jQuery插件的写法(需要传入操作对象)        ;(function ...

  6. NGUI 添加回调函数

    //缓动完成 TweenPosition tweenPos=GetComponent<TweenPosition>(); tweenPos.AddOnFinished(complete); ...

  7. jquery mutilselect 插件添加中英文自动补全

    jquery mutilselect默认只能根据设置的option来进行自动提示 $.each(availableTags, function(key, value) { $('#channels') ...

  8. 给jquery-validation插件添加控件的验证回调方法

    jquery-validation.js在前端验证中使用起来非常方便,提供的功能基本上能满足大部分验证需求,例如:1.内置了很多常用的验证方法:2.可以自定义错误显示信息:3.可以自定义错误显示位置: ...

  9. jQuery使用():Callbacks回调函数列表之异步编程(含源码分析)

    Callbacks的基本功能回调函数缓存与调用 特定需求模式的Callbacks Callbacks的模拟源码 一.Callbacks的基本功能回调函数缓存与调用 Callbacks即回调函数集合,在 ...

随机推荐

  1. Qt之Windows资源文件(.rc文件)

    简述 在Windows下使用Qt时,通常会用到Windows的资源文件 - 为exe设置信息,其中包括:文件说明.产品名称.产品版本.版权等信息... 由于是Windows平台相关的东西,Qt助手中对 ...

  2. 2015第10周四-CSS小结

    这两天做前台页面发现个人在CSS前端方法很多基础知识都忘了,晚上又搜索学习了下,把相关内容摘录总结. CSS 规则由两个主要的部分构成:选择器,以及一条或多条声明. selector {declara ...

  3. POJ1988 并查集的使用

    Cube Stacking Time Limit: 2000MS   Memory Limit: 30000K Total Submissions: 21157   Accepted: 7395 Ca ...

  4. 关于set和map的用法

    1.set 定义:每个元素最多只出现一次,并且默认的是从小到大排序. set 遍历: 题目http://www.cnblogs.com/ZP-Better/p/4700218.html for(set ...

  5. textField 判断输入长度限制

    - (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementS ...

  6. Spring的MethodInvokingFactoryBean

    通过MethodInvokingFactoryBean 可以向某静态方法注入参数. 如: <bean class="org.springframework.beans.factory. ...

  7. Ffmpeg和SDL创建线程(转)

    Spawning Threads Overview Last time we added audio support by taking advantage of SDL's audio functi ...

  8. tomcat建立虚拟主机

    WEB浏览器与WEBserver建立连接后,除了将请求URL中的资源路径发送给WEBserver外,还会将URL中的主机名部分作为HTTP请求消息的Host头发送给WEBserver.比如,在浏览器地 ...

  9. java的wait和notifyAll使用方法

    class Num { private int num; public int getNum() { return num; } public void setNum(int num) { this. ...

  10. Entity Framework with MySQL

    Get Entity Framework: http://msdn.microsoft.com/en-us/data/ee712906 Entity Framework 6 Tools for Vis ...