js事件on动态绑定数据,绑定多个事件的方法


Posted in Javascript onSeptember 15, 2018

一.on('clcik')与$('').clcik()方法的区别:

on('clcik'):事件委托机制

// 在body元素上绑定click事件处理函数handler,如果这个click事件是由其后代的P元素触发的,就执行handler
$(document.body).on("click", "p", handler);

事件委托机制就是,我们不为每个P元素直接绑定click事件处理函数,而是委托给其某个公共的祖辈元素(此处示例中为document.body),"告诉"他:如果接收到了click事件触发通知,并且这个click事件是由我们这些P元素其中之一触发的,就执行祖辈元素上委托绑定的事件处理函数。

注意:"focus"、"blur"等部分事件不支持冒泡,使用事件委托机制将无效。不过,他们一般也有对应的支持冒泡的事件。例如与"focus"对应的"focusin",与"blur"对应的"focusout"。此外,我们也可以使用event.stopPropagation()方法,让当前触发的事件停止冒泡。

1.绑定多个事件,用空格隔开事件和命名空间如:“click”或“keydown.myPlugin”。或者格式为

on({

"clcik": function(){},

mouseover: function(){}

})

命名空间: namespace 名字{ 定义的数据; 定义的函数; 也可以是定义的类...}

2.可以给动态元素和属性绑定事件

clcik()不能为页面动态加载元素添加事件,事件只能为clcik

二:on()的参数

$().on(events,[seletor],[data],fn)或events-map,[seletor],[data]

events:一个或多个用空格分隔的事件类型和可选的命名空间

events-map:个用字符串表示的,一个或多个空格分隔的事件类型和可选的命名空间,值表示事件绑定的处理函数。

seletor:一个选择器字符串用于过滤器的触发事件的选择器元素的后代。如果选择的< null或省略,当它到达选定的元素,事件总是触发。(也就是触发事件元素)

data:当一个事件被触发时要传递event.data给事件处理函数。
fn:该事件被触发时执行的函数。如果事件处理函数handler仅仅只为返回false值,可以直接将handler设为false。false 值也可以做一个函数的简写,返回false。

如果要取消默认事件直接加false

$("form").on("submit", false)

map:规定事件映射 ({event:function, event:function, ...}),包含要添加到元素的一个或多个事件,以及当事件发生时运行的函数

三:onclick,click,on()的优先关系:onclick>click>on();

以上这篇js事件on动态绑定数据,绑定多个事件的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
7个Javascript地图脚本整理
Oct 20 Javascript
JavaScript Perfection kill 测试及答案
Mar 23 Javascript
在javaScript中关于submit和button的区别介绍
Oct 20 Javascript
js实现收缩菜单效果实例代码
Oct 30 Javascript
Java/JS获取flash高宽的具体方法
Dec 27 Javascript
javascript/jquery获取地址栏url参数的方法
Mar 05 Javascript
js获取下拉列表的值和元素个数示例
May 07 Javascript
javascript模拟map输出与去除重复项的方法
Feb 09 Javascript
js实现横向伸展开的二级导航菜单代码
Aug 28 Javascript
jquery实现下拉框功能效果【实例代码】
May 06 Javascript
JavaScript无缝滚动效果的实例代码
Mar 27 Javascript
Kindeditor单独调用单图上传增加预览功能的实例
Jul 31 Javascript
vue 的点击事件获取当前点击的元素方法
Sep 15 #Javascript
对Vue.js之事件的绑定(v-on: 或者 @ )详解
Sep 15 #Javascript
vue绑定事件后获取绑定事件中的this方法
Sep 15 #Javascript
浅谈vue方法内的方法使用this的问题
Sep 15 #Javascript
微信小程序动态增加按钮组件
Sep 14 #Javascript
vue中Element-ui 输入银行账号每四位加一个空格的实现代码
Sep 14 #Javascript
解决vue 格式化银行卡(信用卡)每4位一个符号隔断的问题
Sep 14 #Javascript
You might like
php 正则匹配函数体
2009/08/25 PHP
深入HTTP响应状态码速查表的详解
2013/06/07 PHP
PHP修改session_id示例代码
2014/01/08 PHP
php中str_pad()函数用法分析
2017/03/28 PHP
PHP编程计算文件或数组中单词出现频率的方法
2017/05/22 PHP
PHP操作Redis数据库常用方法示例
2018/08/25 PHP
表单项的name命名为submit、reset引起的问题
2007/12/22 Javascript
js拖拽一些常见的思路方法整理
2014/03/19 Javascript
浅析javascript中function 的 length 属性
2014/05/27 Javascript
js中document.write的那点事
2014/12/12 Javascript
JavaScript中几种排序算法的简单实现
2015/07/29 Javascript
js实现带圆角的多级下拉菜单效果
2015/08/28 Javascript
基于jQuery和CSS3制作响应式水平时间轴附源码下载
2015/12/20 Javascript
javascript使用 concat 方法对数组进行合并的方法
2016/09/08 Javascript
jQuery简单绑定单个事件的方法示例
2017/06/10 jQuery
基于jquery的on和click的区别详解
2018/01/15 jQuery
JS通过识别id、value值对checkbox设置选中状态
2020/02/19 Javascript
通过vue刷新左侧菜单栏操作
2020/08/06 Javascript
深入解析Python中的上下文管理器
2016/06/28 Python
python 自动化将markdown文件转成html文件的方法
2016/09/23 Python
Python3实现发送QQ邮件功能(附件)
2020/12/23 Python
Python并发:多线程与多进程的详解
2019/01/24 Python
python通过链接抓取网站详解
2019/11/20 Python
python图形用户接口实例详解
2019/12/16 Python
在tensorflow中实现去除不足一个batch的数据
2020/01/20 Python
关于python tushare Tkinter构建的简单股票可视化查询系统(Beta v0.13)
2020/10/19 Python
[原创]赚疯了!转手立赚800+?大佬的python「抢茅台脚本」使用教程
2021/01/12 Python
党员违纪检讨书
2014/02/18 职场文书
勾股定理课后反思
2014/04/26 职场文书
建材投资建议书
2014/05/16 职场文书
2015年部门工作总结范文
2015/03/31 职场文书
法定代表人身份证明书
2015/06/18 职场文书
pytorch 如何把图像数据集进行划分成train,test和val
2021/05/31 Python
分享几个简单MySQL优化小妙招
2022/03/31 MySQL
vue实现拖拽交换位置
2022/04/07 Vue.js
mysql数据库实现设置字段长度
2022/06/10 MySQL