jQuery中 delegate使用的问题
2015-07-03 00:00
531 查看
习惯了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...)
以上所述就是本文的全部内容了,希望大家能够喜欢。
相关文章推荐
- jQuery+AJAX实现无刷新下拉加载更多
- 解决jquery实现的radio重新选中的问题
- jQuery动态背景图片效果实现方法
- 在easyui中在同一列中合并相同连续值的jquery插件
- jquery中select的用法
- JQuery实战---用户名校验
- jquery checkbox radio
- 小谷的战斗Jquery(三)--水平和垂直菜单
- jQuery实现输入框获取焦点和失去焦点
- jquery固定在顶部的导航菜单
- jquery源码之when
- jquery基础-包裹 替换 删除 复制
- jquery-validate
- jquery实现图片预加载
- jquery 获取和设置 select下拉框的值
- jquery.min.map详见
- jQuery插件AjaxFileUpload文件上传实现Javascript多文件上传功能
- jQuery插件AjaxFileUpload文件上传实现Javascript多文件上传功能
- 看看该死的jquery.form.js的用法,不是个东西
- jQuery Easy UI LinkButton(button)包