源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

jQuery中 delegate使用的问题

  • 时间:2020-12-22 01:09 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:jQuery中 delegate使用的问题
习惯了bind,用惯了live,就不习惯delegate了呀有木有... 支持为动态生成的标签元素绑定事件也许就live和delegate了吧,不过新版本已经不支持live了,只有delegate delegate真的比较特殊呀,不同于其他事件绑定的风格。 就因为习惯了之前的bind风格..栽了跟头 简单的说就是大意了。 delegate() 方法为指定的元素(属于被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数。 使用 delegate() 方法的事件处理程序适用于当前或未来的元素(比如由脚本创建的新元素)。 [b]语法[/b]
$(selector).delegate(childSelector,event,data,function)
参数 描述
[i]childSelector[/i] 必需。规定要附加事件处理程序的一个或多个子元素。
[i]event[/i]

必需。规定附加到元素的一个或多个事件。 由空格分隔多个事件值。必须是有效的事件。

[i]data[/i] 可选。规定传递到函数的额外数据。
[i]function[/i] 必需。规定当事件发生时运行的函数。

比如这段小代码啊
<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...) 以上所述就是本文的全部内容了,希望大家能够喜欢。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部