jquery中关于事件绑定的问题
2017-12-28 14:57
309 查看
jquery中的事件绑定方法:
1.将事件绑定到document上,当整个dom中发生点击事件时会先判断当前点击的对象是否匹配该className,再执行点击的回调方法。适用于多组重复元素的点击事件。
$(document).on('click','.className',function(){});2.将事件绑定到该className的元素上,一旦该元素发生点击事件立即执行回调方法。如果是单独的元素点击事件,用此种绑定方法更为高效。缺点是只在页面加载的时候绑定一次,无法获取后加载在页面上的元素。$('.className').on('click',function(){});举例:
导航栏的切换动作
$(document).on("click","ul li",function(){
$(this).addClass("changeBgColor").siblings().removeClass("changeBgColor")
});由于导航菜单(li)并不是写死在页面上,而是由数据库读取,并循环显示在页面上,此时用第二种绑定方法无法获取“li”,因此要用第一种绑定方式,且此时不需要判断是哪一个”li“发生了点击事件,因为$(ducoment).on()方法会自动判断是哪一个。注:若”li“元素是写死在页面上的,则可以使用第二种绑定方式,这里需要用$(this).index()方法来判断是哪一个li发生点击事件,而上面一种方法则不需要手动进行判断。如下:
$(‘ul li’).on(“click”,function(){
$(‘ul li’).eq($(this).index()).addClass(“changeBgColor”).siblings().removeClass(“changeBgColor”)
});
1.将事件绑定到document上,当整个dom中发生点击事件时会先判断当前点击的对象是否匹配该className,再执行点击的回调方法。适用于多组重复元素的点击事件。
$(document).on('click','.className',function(){});2.将事件绑定到该className的元素上,一旦该元素发生点击事件立即执行回调方法。如果是单独的元素点击事件,用此种绑定方法更为高效。缺点是只在页面加载的时候绑定一次,无法获取后加载在页面上的元素。$('.className').on('click',function(){});举例:
导航栏的切换动作
$(document).on("click","ul li",function(){
$(this).addClass("changeBgColor").siblings().removeClass("changeBgColor")
});由于导航菜单(li)并不是写死在页面上,而是由数据库读取,并循环显示在页面上,此时用第二种绑定方法无法获取“li”,因此要用第一种绑定方式,且此时不需要判断是哪一个”li“发生了点击事件,因为$(ducoment).on()方法会自动判断是哪一个。注:若”li“元素是写死在页面上的,则可以使用第二种绑定方式,这里需要用$(this).index()方法来判断是哪一个li发生点击事件,而上面一种方法则不需要手动进行判断。如下:
$(‘ul li’).on(“click”,function(){
$(‘ul li’).eq($(this).index()).addClass(“changeBgColor”).siblings().removeClass(“changeBgColor”)
});
相关文章推荐
- 关于标签onclick方法失效,或jquery绑定事件失效的问题
- 关于jquery on方法进行事件绑定触发次数指数叠加的问题
- 关于jQuery动态加载元素之后绑定事件无法触发的问题
- 关于jquery中用on绑定事件后的事件冒泡问题
- 关于jquery input textare 事件绑定
- jquery bind('click')传参问题(例如:列表中每行绑定一个事件)
- 解决jquery动态创建元素绑定事件失效问题
- jQuery中on绑定事件后引发的事件冒泡问题如何解决
- 关于如何绑定Jquery 的scroll事件(兼容浏览器 Wookmark瀑布流插件)
- 关于jQuery事件绑定
- 关于jquery某一元素重复绑定的问题
- jquery重复绑定事件问题
- 对JQuery在循环中绑定事件的问题理解
- 关于jQuery新的事件绑定机制on()的使用技巧
- jQuery事件问题 对jQuery.ajax异步创建的html元素的绑定事件 必须在success里重新绑定 否则无效
- 关于ajax局部刷新后,js绑定事件失效的问题
- JQuery在循环中绑定事件的问题详解
- 关于ECMA 和 jquery事件绑定的两个mark
- 关于原生事件绑定中attachEvent与addEventlistener中兼容性以及attachEvent函数中this指代window问题
- JQuery绑定input[type=file]的change事件问题