jQuery改造插件,添加回调函数
- <script language="javascript" type="text/javascript">
- function doSomething(callback) {
- // …
- // Call the callback
- callback('stuff', 'goes', 'here'); // 给callback赋值,callback是个函数变量
- }
- function foo1(a, b, c) {
- // I'm the callback
- alert(a + " " + b + " " + c);
- }
- doSomething(foo1); // foo1函数将使用callback函数中的数据 stuff goes here
- var foo2 = function(a,b,c) {
- // I'm the callback
- alert(a + " " + b + " " + c);
- }
- doSomething(foo2); // foo2函数将使用callback函数中的数据 stuff goes here
- doSomething(function(a,b,c){
- alert(a + " " + b + " " + c); // function函数将使用callback函数中的数据 stuff goes here
- });
- </script>
callback这个参数必须是函数才有效。才能起到回调的作用。
- <script language="javascript" type="text/javascript">
- function doSomething(callback) {
- // …
- // Call the callback
- if(typeof callback === 'function'){
- callback('stuff', 'goes', 'here'); // 给callback赋值,callback是个函数变量
- }else{
- alert('fuck you');
- }
- }
- function foo1(a, b, c) {
- // I'm the callback
- alert(a + " " + b + " " + c);
- }
- doSomething(foo1); // foo1函数将使用callback函数中的数据 stuff goes here
- var foo2 = function(a,b,c) {
- // I'm the callback
- alert(a + " " + b + " " + c);
- }
- doSomething(foo2); // foo2函数将使用callback函数中的数据 stuff goes here
- doSomething(function(a,b,c){
- alert(a + " " + b + " " + c); // function函数将使用callback函数中的数据 stuff goes here
- });
- var foo3 = 'a';
- doSomething(foo3);
- </script>
foo3不是函数的时候,弹出fuck you
jQuery实例
原函数
- $.fn.citySelect=function(settings)
添加回调
- $.fn.citySelect=function(settings, changeHandle) // 添加回调函数changeHandle
给回调函数赋值
- //选项变动赋值事件
- var selectChange = function (areaType) {
- if(typeof changeHandle === 'function'){ // 判断callback是否是函数
- var prov_id = prov_obj.get(0).selectedIndex;
- var city_id = city_obj.get(0).selectedIndex;
- var dist_id = dist_obj.get(0).selectedIndex;
- if(!settings.required){
- prov_id--;
- city_id--;
- dist_id--;
- };
- if(dist_id<0){
- var data = {
- prov: city_json.citylist[prov_id].p,
- city: city_json.citylist[prov_id].c[city_id].n,
- dist: null
- };
- }else{
- var data = {
- prov: city_json.citylist[prov_id].p,
- city: city_json.citylist[prov_id].c[city_id].n,
- dist: city_json.citylist[prov_id].c[city_id].a[dist_id].s
- };
- }
- changeHandle(data, areaType); // 返回两个处理好的数据
- }
- };
获取省市县数据data以及触发的change事件类型areaType
- // 选择省份时发生事件
- prov_obj.bind("change",function(){
- cityStart();
- selectChange('prov'); // 返回数据
- });
- // 选择市级时发生事件
- city_obj.bind("change",function(){
- distStart();
- selectChange('city'); // 返回数据
- });
- // 选择区级时发生事件
- dist_obj.bind("change",function(){
- selectChange('dist'); // 返回数据
- });
在各个事件中执行
前端使用
- $("#s_city").citySelect({
- prov: "江苏省",
- city: "宿迁市",
- dist: "宿城区",
- nodata: "none"
- },
- function(data, type) {
- selectAgent(data.city, data.dist);
- });
使用回调回来的data数据,用于selectAgent函数中
- function selectAgent(city,district){
- $.ajax({
- type:"POST",
- url:"{sh::U('Index/ajax',array('todo'=>'getagent'))}",
- data:"city="+city+"&district="+district,
- success:function(json){
- json = JSON.parse(json);
- opt_str = "<option value=''>-请选择-</option>"
- if(json.status == 1){
- $.each(json.data,function(index,con){
- opt_str += "<option value="+con.id+">"+con.name+" 电话:"+con.tel+"</option>"
- })
- }
- $('#agent_id').html(opt_str);
- }
- });
- }
去ajax获取相应的代理商数据。
改造插件完成。
jQuery改造插件,添加回调函数的更多相关文章
- jquery Ajax 不执行回调函数success的原因
jquery Ajax 不执行回调函数success的原因: $.ajax({ type: "post", contentType: "application/json& ...
- jQuery编写插件--封装全局函数的插件(一些常用的js验证表达式)
上一篇写到了jQuery插件的3种类型,介绍了第一种类型的写法--封装jQuery对象的方法插件.这一篇要介绍第二种插件类型:封装全局函数的插件:这类插件就是在jQuery命名空间内部添加函数:这类插 ...
- javascript与jQuery的each,map回调函数参数顺序问题
<script> var arr = [2,3,6,7,9]; //javascript中的forEach 和 map方法 arr.forEach(function(value,index ...
- jQuery hide() 参数callback回调函数执行问题
$("#b").click(function() { $("div").hide(1000,bbb); //-------------1 bbb是一个函数,但这 ...
- jQuery扩展插件和拓展函数的写法
<script type="text/JavaScript"> //jQuery插件的写法(需要传入操作对象) ;(function ...
- NGUI 添加回调函数
//缓动完成 TweenPosition tweenPos=GetComponent<TweenPosition>(); tweenPos.AddOnFinished(complete); ...
- jquery mutilselect 插件添加中英文自动补全
jquery mutilselect默认只能根据设置的option来进行自动提示 $.each(availableTags, function(key, value) { $('#channels') ...
- 给jquery-validation插件添加控件的验证回调方法
jquery-validation.js在前端验证中使用起来非常方便,提供的功能基本上能满足大部分验证需求,例如:1.内置了很多常用的验证方法:2.可以自定义错误显示信息:3.可以自定义错误显示位置: ...
- jQuery使用():Callbacks回调函数列表之异步编程(含源码分析)
Callbacks的基本功能回调函数缓存与调用 特定需求模式的Callbacks Callbacks的模拟源码 一.Callbacks的基本功能回调函数缓存与调用 Callbacks即回调函数集合,在 ...
随机推荐
- Qt之Windows资源文件(.rc文件)
简述 在Windows下使用Qt时,通常会用到Windows的资源文件 - 为exe设置信息,其中包括:文件说明.产品名称.产品版本.版权等信息... 由于是Windows平台相关的东西,Qt助手中对 ...
- 2015第10周四-CSS小结
这两天做前台页面发现个人在CSS前端方法很多基础知识都忘了,晚上又搜索学习了下,把相关内容摘录总结. CSS 规则由两个主要的部分构成:选择器,以及一条或多条声明. selector {declara ...
- POJ1988 并查集的使用
Cube Stacking Time Limit: 2000MS Memory Limit: 30000K Total Submissions: 21157 Accepted: 7395 Ca ...
- 关于set和map的用法
1.set 定义:每个元素最多只出现一次,并且默认的是从小到大排序. set 遍历: 题目http://www.cnblogs.com/ZP-Better/p/4700218.html for(set ...
- textField 判断输入长度限制
- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementS ...
- Spring的MethodInvokingFactoryBean
通过MethodInvokingFactoryBean 可以向某静态方法注入参数. 如: <bean class="org.springframework.beans.factory. ...
- Ffmpeg和SDL创建线程(转)
Spawning Threads Overview Last time we added audio support by taking advantage of SDL's audio functi ...
- tomcat建立虚拟主机
WEB浏览器与WEBserver建立连接后,除了将请求URL中的资源路径发送给WEBserver外,还会将URL中的主机名部分作为HTTP请求消息的Host头发送给WEBserver.比如,在浏览器地 ...
- java的wait和notifyAll使用方法
class Num { private int num; public int getNum() { return num; } public void setNum(int num) { this. ...
- Entity Framework with MySQL
Get Entity Framework: http://msdn.microsoft.com/en-us/data/ee712906 Entity Framework 6 Tools for Vis ...