jQuery中 delegate使用的问题

 更新时间:2015年07月03日 10:08:38   投稿:hebedich  
本文主要给大家介绍的是在jQuery中使用delegate的时候遇到的几个小小的坑,主要是习惯了使用bind,live,一时改不过来的问题,这里记录下来推荐给大家。

习惯了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中$之选择器用法介绍

    JQuery中$之选择器用法介绍

    在jQuery 中$("<span>"),这个语法等同于$(document.createElement("span")) ,这是一种用法
    2011-04-04
  • jquery中添加属性和删除属性

    jquery中添加属性和删除属性

    本文给大家介绍的是jquery中添加属性和删除属性的方法和具体的示例,有需要的小伙伴可以参考下
    2015-06-06
  • jquery实现简单实用的弹出层效果代码

    jquery实现简单实用的弹出层效果代码

    这篇文章主要介绍了jquery实现简单实用的弹出层效果代码,涉及jquery响应鼠标事件动态操作页面元素属性的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10
  • jQuery siblings()用法实例详解

    jQuery siblings()用法实例详解

    siblings() 获得匹配集合中每个元素的同胞,通过选择器进行筛选是可选的。接下来通过本文给大家介绍jQuery siblings()用法实例详解,需要的朋友参考下吧
    2016-04-04
  • 给Easyui-Datebox设置隐藏或者不可用的解决方法

    给Easyui-Datebox设置隐藏或者不可用的解决方法

    最近我在做一个安全监测系统,选择了用easyui进行搭建,easyui是一种基于jQuery的用户界面插件集合。使用easyui可以省去很多代码,功能上需要加一些样式。下面小编给大家介绍下给Easyui-Datebox设置隐藏或者不可用的解决方法
    2017-05-05
  • jQuery实现大图轮播

    jQuery实现大图轮播

    本文主要分享了jQuery实现大图轮播的示例代码。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-02-02
  • jQuery实现的鼠标拖动浮层功能示例【拖动div等任何标签】

    jQuery实现的鼠标拖动浮层功能示例【拖动div等任何标签】

    这篇文章主要介绍了jQuery实现的鼠标拖动浮层功能,可实现拖动div等任何标签的效果,涉及jQuery事件响应及页面元素属性动态操作相关实现技巧,需要的朋友可以参考下
    2018-12-12
  • 用jQuery获取IE9下拉框默认值问题探讨

    用jQuery获取IE9下拉框默认值问题探讨

    本文与大家详细探讨下用jQuery获取IE9下拉框默认值的问题,如果下拉框没有空默认值会怎么样等一系列问题,感兴趣的朋友可以参考下哈,希望对大家有所帮助
    2013-07-07
  • jQuery使用手册之 事件处理

    jQuery使用手册之 事件处理

    jQuery使用手册之 事件处理...
    2007-03-03
  • jQuery实现设置、移除文本框默认值功能

    jQuery实现设置、移除文本框默认值功能

    这篇文章主要介绍了jQuery实现设置、移除文本框默认值功能,本文实现是类似html5 placeholder(空白提示)效果,正常时文本框有提示文字,当文本框获得焦点时变为空白,需要的朋友可以参考下
    2015-01-01

最新评论