手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >jQuery中 delegate使用的问题
jQuery中 delegate使用的问题
摘要:习惯了bind,用惯了live,就不习惯delegate了呀有木有...支持为动态生成的标签元素绑定事件也许就live和delegate了吧...

习惯了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="http://www.jb51.netjquery/jquery.js"></script> <script type="text/javascript"> $(document).ready(function(){ $("div").delegate("button","click",function(){ $("p").slideToggle(); }); }); </script> </head> <body> <div> <p>这是一个段落。</p> <button>请点击这里</button> </div> </body> </html>

我老写成了

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

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

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

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

【jQuery中 delegate使用的问题】相关文章:

AngularJs中route的使用方法和配置

jquery.validate使用时遇到的问题

DIV任意拖动的问题

JavaScript中eval函数的问题

JQuery中Text方法用法实例分析

JavaScript中substring()方法的使用

jQuery实现dialog设置focus焦点的方法

javascript中createElement的两种创建方式

详解AngularJS中的表达式使用

在JavaScript中使用JSON数据

精品推荐
分类导航