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 中使用JSON的实现代码
Dec 01 Javascript
window.event.keyCode兼容IE和Firefox实现js代码
May 30 Javascript
js 调用父窗口的具体实现代码
Jul 15 Javascript
JavaScript跨域方法汇总
Oct 16 Javascript
使用jQuery实现input数值增量和减量的方法
Jan 24 Javascript
JS遍历数组和对象的区别及递归遍历对象、数组、属性的方法详解
Jun 14 Javascript
微信小程序 天气预报开发实例代码源码
Jan 20 Javascript
JavaScript中在光标处插入添加文本标签节点的详细方法
Mar 22 Javascript
对于input 框限定输入值为浮点型的js代码
Sep 25 Javascript
node通过npm写一个cli命令行工具
Oct 12 Javascript
微信小程序实现点击按钮修改文字大小功能【附demo源码下载】
Dec 06 Javascript
详解JavaScript的数据类型以及数据类型的转换
Apr 20 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
一个oracle+PHP的查询的例子
2006/10/09 PHP
PHP Memcached应用实现代码
2010/02/08 PHP
php判断上传的Excel文件中是否有图片及PHPExcel库认识
2013/01/11 PHP
yii2.0整合阿里云oss删除单个文件的方法
2017/09/19 PHP
php适配器模式简单应用示例
2019/10/23 PHP
JQuery 无废话系列教程(一) jquery入门 [推荐]
2009/06/23 Javascript
javascript检测对象中是否存在某个属性判断方法小结
2013/05/19 Javascript
js 固定悬浮效果实现思路代码
2013/08/02 Javascript
JavaScript中的单引号和双引号报错的解决方法
2014/09/01 Javascript
JS 实现列表与多选框选择附预览动画
2014/10/29 Javascript
js实现的简洁网页滑动tab菜单效果代码
2015/08/24 Javascript
第八篇Bootstrap下拉菜单实例代码
2016/06/21 Javascript
fullpage.js全屏滚动插件使用实例
2016/09/06 Javascript
利用js定义一个导航条菜单
2017/03/14 Javascript
详谈jQuery中使用attr(), prop(), val()获取value的异同
2017/04/25 jQuery
js数据类型检测总结
2018/08/05 Javascript
JavaScript指定断点操作实例教程
2018/09/18 Javascript
Nodejs对postgresql基本操作的封装方法
2019/02/20 NodeJs
vue基础之事件v-onclick=&quot;函数&quot;用法示例
2019/03/11 Javascript
javascript设计模式之迭代器模式
2020/01/30 Javascript
Vue实现剪切板图片压缩功能
2020/02/04 Javascript
15个简单的JS编码标准让你的代码更整洁(小结)
2020/07/16 Javascript
原生JS生成指定位数的验证码
2020/10/28 Javascript
使用python统计文件行数示例分享
2014/02/21 Python
探寻python多线程ctrl+c退出问题解决方案
2014/10/23 Python
利用Django框架中select_related和prefetch_related函数对数据库查询优化
2015/04/01 Python
python实现暗通道去雾算法的示例
2020/09/27 Python
Django 实现图片上传和下载功能
2020/12/31 Python
css3 border-radius属性详解
2017/07/05 HTML / CSS
小学三年级数学教学反思
2014/01/31 职场文书
留学推荐信范文
2014/05/10 职场文书
副科竞争上岗演讲稿
2014/05/12 职场文书
投标文件签署授权委托书范本
2014/10/12 职场文书
幼儿园见习报告
2014/10/30 职场文书
Jupyter Notebook内使用argparse报错的解决方案
2021/06/03 Python
美元符号 $
2022/02/17 杂记