jQuery学习笔记之回调函数


Posted in Javascript onAugust 15, 2016

1.回调函数定义

回调函数就是一个通过函数指针调用的函数。如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数。回调函数不是由该函数的实现方直接调用,而是在特定的事件或条件发生时由另外的一方调用的,才会真正的执行回调函数内部的方法。

2.代码

JS代码

(function($){
$.fn.shadow = function(opts){
//定义的默认的参数
var defaults = {
copies: 5,
opacity:0.1,
//回调函数
copyOffset:function(index){
return{x:index,y:index};
}
};
//将opts的内容合并到default中。
var options = $.extend(defaults,opts);
return this.each(function(){
var $originalElement = $(this);
//设置参数对象
for(var i=0;i<options.copies;i++)
{
var offset = options.copyOffset(i);
$originalElement
.clone()
.css({
position:'absolute',
left:$originalElement.offset().left + offset.x,
top:$originalElement.offset().top + offset.y,
margin:0,
zIndex:-1,
//设置参数对象
opacity:options.opacity
})
.appendTo('body');
}
});
};
})(jQuery);
$(document).ready(function(){
$('h1').shadow({
copies:5,
copyOffset:function(index){
return {x:-index,y:-2 * index};
}
});
});

3.分析

通过这段代码调试的时候进入的顺序,便可理解回调函数的机制。通过对黄背景的四段代码加入断点。程序将会以以下的顺序运行

39:先跑第39行,当DOM加载完毕后运行了shadow(),跑完39行并不会直接跑40行。而是直接调到了shadow()函数定义的地方。在这里只是声明了copyOffset的函数指针。

2:这时候查看opts里面的内容Object { copies=5, copyOffset=function()}从这里可以看出来copyOffset只是一个function(),

8:开始走默认参数的copyOffset,与39行一样,不会直接进入回调函数里面的内容。

19:走到这里时,需要将对CopyOffset发出请求并传入了i作为参数。这时候i就是回调函数的参数index。

40:由于13行的”var options = $.Extend(defauflts,opts)”。opts的属性会覆盖掉default的属性,所以不会走9行默认的参数中的回调函数的执行方法,而是走了第40行的回调函数的方法。

4.总结

从上面的分析可以看出,回调函数在参数中声明时,相当于只是声明了一个委托。等到用到这个参数的时候才会真正的执行回调函数里面的内容。

5.附html代码

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Developing Plugins</title>
<link rel="stylesheet" href="08.css" type="text/css" />
<link rel="stylesheet" href="ui-themes/smoothness/jquery-ui-1.10.0.custom.css" type="text/css" />
<script src="jquery.js"></script>
<script src="jquery-ui-1.10.0.custom.min.js"></script>
<script src="08.js"></script>
</head>
<body>
<div id="container">
<h1>Inventory</h1>
<table id="inventory">
<thead>
<tr class="two">
<th>Product</th>
<th>Quantity</th>
<th>Price</th>
</tr>
</thead>
<tfoot>
<tr class="two" id="sum">
<td>Total</td>
<td></td>
<td></td>
</tr>
<tr id="average">
<td>Average</td>
<td></td>
<td></td>
</tr>
</tfoot>
<tbody>
<tr>
<td><a href="spam.html" data-tooltip-text="Nutritious and delicious!">Spam</a></td>
<td>4</td>
<td>2.50</td>
</tr>
<tr>
<td><a href="egg.html" data-tooltip-text="Farm fresh or scrambled!">Egg</a></td>
<td>12</td>
<td>4.32</td>
</tr>
<tr>
<td><a href="gourmet-spam.html" data-tooltip-text="Chef Hermann's recipe.">Gourmet Spam</a></td>
<td>14</td>
<td>7.89</td>
</tr>
</tbody>
</table>
</div>
</body>
</html>

以上所述是小编给大家介绍的jQuery学习笔记之回调函数,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript当onmousedown、onmouseup、onclick同时应用于同一个标签节点Element
Jan 05 Javascript
jquery获取一组checkbox的值(实例代码)
Nov 04 Javascript
Select标签下拉列表二级联动级联实例代码
Feb 07 Javascript
JavaScript中的方法重载实例
Mar 16 Javascript
JavaScript中的条件判断语句使用详解
Jun 03 Javascript
js实现的Easy Tabs选项卡用法实例
Sep 06 Javascript
JS+HTML5 FileReader对象用法示例
Apr 07 Javascript
实现一个完整的Node.js RESTful API的示例
Sep 29 Javascript
微信小程序实现音乐播放器
Nov 20 Javascript
解决VantUI popup 弹窗不弹出或无蒙层的问题
Nov 03 Javascript
Vue指令实现OutClick的示例
Nov 16 Javascript
详解vue中v-for的key唯一性
May 15 Vue.js
纯css下拉菜单 无需js
Aug 15 #Javascript
浅谈JavaScript 中有关时间对象的方法
Aug 15 #Javascript
js轮盘抽奖实例分析
Apr 17 #Javascript
JavaScript 中有关数组对象的方法(详解)
Aug 15 #Javascript
onmouseover事件和onmouseout事件全面理解
Aug 15 #Javascript
浅谈toLowerCase和toLocaleLowerCase的区别
Aug 15 #Javascript
又一款js时钟!transform实现时钟效果
Aug 15 #Javascript
You might like
表单复选框向PHP传输数据的代码
2007/11/13 PHP
PHP以及MYSQL日期比较方法
2012/11/29 PHP
基于session_unset与session_destroy的区别详解
2013/06/03 PHP
php json_encode值中大括号与花括号区别
2013/09/30 PHP
php检测网页是否被百度收录的函数代码
2013/10/09 PHP
php查询mssql出现乱码的解决方法
2014/12/29 PHP
PHP实现事件机制实例分析
2015/06/26 PHP
PHP访问数据库集群的方法小结
2016/03/14 PHP
PHP6连接SQLServer2005的三部曲
2016/04/15 PHP
Laravel框架实现超简单的分页效果示例
2019/02/08 PHP
使用JavaScript动态设置样式实现代码(2)
2013/01/25 Javascript
JS仿百度搜索自动提示框匹配查询功能
2013/11/21 Javascript
使用jQuery.form.js/springmvc框架实现文件上传功能
2016/05/12 Javascript
js实现四舍五入完全保留两位小数的方法
2016/08/02 Javascript
关于js中的鼠标事件总结
2017/07/11 Javascript
浅谈Vuejs Prop基本用法
2017/08/17 Javascript
Vue.js 2.0和Cordova开发webApp环境搭建方法
2018/02/26 Javascript
vue中post请求以a=a&amp;b=b 的格式写遇到的问题
2018/04/27 Javascript
JavaScript实现图片伪异步上传过程解析
2020/04/10 Javascript
[01:29]2014DOTA2展望TI 剑指西雅图DK战队专访
2014/06/30 DOTA
基于Python打造账号共享浏览器功能
2019/05/30 Python
python的pytest框架之命令行参数详解(下)
2019/06/27 Python
python实现logistic分类算法代码
2020/02/28 Python
python中什么是面向对象
2020/06/11 Python
python与c语言的语法有哪些不一样的
2020/09/13 Python
python 密码学示例——理解哈希(Hash)算法
2020/09/21 Python
python 实现简易的记事本
2020/11/30 Python
python openpyxl模块的使用详解
2021/02/25 Python
几款主流好用的富文本编辑器(所见即所得常用编辑器)介绍
2021/03/17 Javascript
canvas实现图片马赛克的示例代码
2018/03/26 HTML / CSS
球队口号
2014/06/18 职场文书
培训班通知
2015/04/25 职场文书
结婚堵门保证书
2015/05/08 职场文书
2016年圣诞节义工活动总结
2016/04/01 职场文书
Python合并多张图片成PDF
2021/06/09 Python
golang内置函数len的小技巧
2021/07/25 Golang