jQuery中 delegate使用的问题


Posted in Javascript onJuly 03, 2015

习惯了bind,用惯了live,就不习惯delegate了呀有木有...

支持为动态生成的标签元素绑定事件也许就live和delegate了吧,不过新版本已经不支持live了,只有delegate

delegate真的比较特殊呀,不同于其他事件绑定的风格。

就因为习惯了之前的bind风格..栽了跟头

简单的说就是大意了。

delegate() 方法为指定的元素(属于被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数。

使用 delegate() 方法的事件处理程序适用于当前或未来的元素(比如由脚本创建的新元素)。

语法

$(selector).delegate(childSelector,event,data,function)

参数 描述
childSelector 必需。规定要附加事件处理程序的一个或多个子元素。
event 必需。规定附加到元素的一个或多个事件。 由空格分隔多个事件值。必须是有效的事件。
data 可选。规定传递到函数的额外数据。
function 必需。规定当事件发生时运行的函数。

比如这段小代码啊

<html>
<head>
<script type="text/javascript" src="/jquery/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
 $("div").delegate("button","click",function(){
  $("p").slideToggle();
 });
});
</script>
</head>
<body>
<div style="background-color:red">
<p>这是一个段落。</p>
<button>请点击这里</button>
</div>

</body>
</html>

我老写成了

$(document).ready(function(){
 $("div").delegate($("button"),"click",function(){
  $("p").slideToggle();
 });
});

子选择器不需要选择起来了..

不然就像我那样出现不知名的错误(点击会触发click,但点击其他元素也会触发click...)

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
Jquery Ajax请求代码(2)
Jan 07 Javascript
javascript中parentNode,childNodes,children的应用详解
Dec 17 Javascript
JavaScript验证图片类型(扩展名)的函数分享
May 05 Javascript
浅谈JS闭包中的循环绑定处理程序
Nov 09 Javascript
jQuery实现新消息闪烁标题提示的方法
Mar 11 Javascript
为何JS操作的href都是javascript:void(0);呢
Nov 12 Javascript
跟我学习javascript的prototype原型和原型链
Nov 18 Javascript
JS提交form表单实例分析
Dec 10 Javascript
axios 封装上传文件的请求方法
Sep 26 Javascript
详解js获取video任意时间的画面截图
Apr 17 Javascript
Jquery+AJAX实现无刷新上传并重命名文件操作示例【PHP后台接收】
May 29 jQuery
javaScript实现一个队列的方法
Jul 14 Javascript
JavaScript实现select添加option
Jul 03 #Javascript
JavaScript定时器和优化的取消定时器方法
Jul 03 #Javascript
Javascript中的作用域和上下文深入理解
Jul 03 #Javascript
JavaScript访问字符串中单个字符的两种方法
Jul 03 #Javascript
JavaScript中解析JSON数据的三种方法
Jul 03 #Javascript
一张Web前端的思维导图分享
Jul 03 #Javascript
JavaScript中的对象与JSON
Jul 03 #Javascript
You might like
Erlang的运算符(比较运算符,数值运算符,移位运算符,逻辑运算符)
2012/07/23 PHP
php调用Google translate_tts api实现代码
2013/08/07 PHP
easyui的tabs update正确用法分享
2014/03/21 PHP
使用PHP把HTML生成PDF文件的几个开源项目介绍
2014/11/17 PHP
php使用for语句输出三角形的方法
2015/06/09 PHP
如何解决PHP获取不到SESSION信息之一般情况
2019/10/10 PHP
FF IE兼容性的修改小结
2009/09/02 Javascript
JS与C#编码解码
2013/12/03 Javascript
JavaScript中的函数重载深入理解
2014/08/04 Javascript
IE6浏览器中window.location.href无效的解决方法
2014/11/20 Javascript
论Bootstrap3和Foundation5网格系统的异同
2016/05/16 Javascript
全面了解JavaScirpt 的垃圾(garbage collection)回收机制
2016/07/11 Javascript
详解如何使用webpack打包多页jquery项目
2019/02/01 jQuery
微信小程序Echarts图表组件使用方法详解
2019/06/25 Javascript
JavaScript canvas绘制渐变颜色的矩形
2020/02/18 Javascript
[01:31:22]Ti4 循环赛第四日附加赛LGD vs Mouz
2014/07/13 DOTA
python实现傅里叶级数展开的实现
2018/07/21 Python
对python生成业务报表的实例详解
2019/02/03 Python
Django网络框架之HelloDjango项目创建教程
2019/06/06 Python
python字符串,元组,列表,字典互转代码实例详解
2020/02/14 Python
Python开发之pip安装及使用方法详解
2020/02/21 Python
Python运行提示缺少模块问题解决方案
2020/04/02 Python
Python 如何测试文件是否存在
2020/07/31 Python
python实现AdaBoost算法的示例
2020/10/03 Python
CSS3实现可爱的小黄人动画
2016/07/11 HTML / CSS
美国最大的存储市场:SpareFoot
2018/07/23 全球购物
SIDESTEP荷兰:在线购买鞋子
2019/11/18 全球购物
俄罗斯在线服装店:STOLNIK
2021/03/07 全球购物
JAVA中的关键字有什么特点
2014/03/07 面试题
介绍一下linux的文件权限
2012/02/15 面试题
大四自我鉴定范文
2013/10/06 职场文书
入党转预备思想汇报
2014/01/07 职场文书
职工代表大会主持词
2014/04/01 职场文书
高校教师个人总结
2015/02/10 职场文书
2015年班长个人工作总结
2015/04/03 职场文书
2016秋季运动会前导词
2015/11/25 职场文书