jquery中怎样对事件进行绑定和解绑?(代码详解)
jQuery事件绑定和解绑
1.1. jQuery 事件注册
jQuery 为我们提供了方便的事件注册机制,是开发人员抑郁操作优缺点如下:
优点: 操作简单,且不用担心事件覆盖等问题。
缺点: 普通的事件注册不能做事件委托,且无法实现事件解绑,需要借助其他方法。
语法
演示代码
body>
div>
/div>
script>
$(function() {
// 1. 单个事件注册 $("div").click(function() {
$(this).css("background", "purple");
}
);
$("div").mouseenter(function() {
$(this).css("background", "skyblue");
}
);
}
) /script>
/body>
1.2. jQuery 事件处理
因为普通注册事件方法的不足,jQuery又开发了多个处理方法,重点讲解如下:
on(): 用于事件绑定,目前最好用的事件绑定方法
off(): 事件解绑
trigger() / triggerHandler(): 事件触发
1.2.1 事件处理 on() 绑定事件
因为普通注册事件方法的不足,jQuery又创建了多个新的事件绑定方法bind() / live() / delegate() / on()等,其中最好用的是: on()
语法
演示代码
body>
div>
/div>
ul>
li>
我们都是好孩子/li>
li>
我们都是好孩子/li>
li>
我们都是好孩子/li>
/ul>
ol>
/ol>
script>
$(function() {
// (1) on可以绑定1个或者多个事件处理程序 // $("div").on({
// mouseenter: function() {
// $(this).css("background", "skyblue");
// }
, // click: function() {
// $(this).css("background", "purple");
// }
// }
);
$("div").on("mouseenter mouseleave", function() {
$(this).toggleClass("current");
}
);
// (2) on可以实现事件委托(委派) // click 是绑定在ul 身上的,但是 触发的对象是 ul 里面的小li // $("ul li").click();
$("ul").on("click", "li", function() {
alert(11);
}
);
// (3) on可以给未来动态创建的元素绑定事件 $("ol").on("click", "li", function() {
alert(11);
}
) VAR li = $("li>
我是后来创建的/li>
");
$("ol").apPEnd(li);
}
) /script>
/body>
1.2.3. 事件处理 off() 解绑事件
当某个事件上面的逻辑,在特定需求下不需要的时候,可以把该事件上的逻辑移除,这个过程我们称为事件解绑。jQuery 为我们提供 了多种事件解绑方法:die() / undelegate() / off() 等,甚至还有只触发一次的事件绑定方法 one(),在这里我们重点讲解一下 off() ;
语法
演示代码
body>
div>
/div>
ul>
li>
我们都是好孩子/li>
li>
我们都是好孩子/li>
li>
我们都是好孩子/li>
/ul>
p>
我是一个p标签/p>
script>
$(function() {
// 事件绑定 $("div").on({
click: function() {
console.LOG("我点击了");
}
, mouseover: function() {
console.log('我鼠标经过了');
}
}
);
$("ul").on("click", "li", function() {
alert(11);
}
);
// 1. 事件解绑 off // $("div").off();
// 这个是解除了div身上的所有事件 $("div").off("click");
// 这个是解除了div身上的点击事件 $("ul").off("click", "li");
// 2. one() 但是它只能触发事件一次 $("p").one("click", function() {
alert(11);
}
) }
) /script>
/body>
1.2.4. 事件处理 trigger() 自动触发事件
有些时候,在某些特定的条件下,我们希望某些事件能够自动触发, 比如轮播图自动播放功能跟点击右侧按钮一致。可以利用定时器自动触发右侧按钮点击事件,不必鼠标点击触发。由此 jQuery 为我们提供了两个自动触发事件 trigger() 和 triggerHandler() ;
语法
演示代码
body>
div>
/div>
input type="text">
script>
$(function() {
// 绑定事件 $("div").on("click", function() {
alert(11);
}
);
// 自动触发事件 // 1. 元素.事件() // $("div").click();
会触发元素的默认行为 // 2. 元素.trigger("事件") // $("div").trigger("click");
会触发元素的默认行为 $("input").trigger("focus");
// 3. 元素.triggerHandler("事件") 就是不会触发元素的默认行为 $("input").on("focus", function() {
$(this).val("你好吗");
}
);
// 一个会获取焦点,一个不会 $("div").triggerHandler("click");
// $("input").triggerHandler("focus");
}
);
/script>
/body>
1.3. jQuery 事件对象
jQuery 对DOM中的事件对象 event 进行了封装,兼容性更好,获取更方便,使用变化不大。事件被触发,就会有事件对象的产生。
语法
演示代码
body>
div>
/div>
script>
$(function() {
$(document).on("click", function() {
console.log("点击了document");
}
) $("div").on("click", function(event) {
// console.log(event);
console.log("点击了div");
event.stopPRopagation();
}
) }
) /script>
/body>
注意:jQuery中的 event 对象使用,可以借鉴 API 和 DOM 中的 event 。
1.4. jQuery 拷贝对象
jQuery中分别为我们提供了两套快速获取和设置元素尺寸和位置的API,方便易用,内容如下。
语法
演示代码
script>
$(function() {
// 1.合并数据 var targetObj = {
}
;
var obj = {
id: 1, name: "andy" }
;
// $.extend(target, obj);
$.extend(targetObj, obj);
console.log(targetObj);
// 2. 会覆盖 targetObj 里面原来的数据 var targetObj = {
id: 0 }
;
var obj = {
id: 1, name: "andy" }
;
// $.extend(target, obj);
$.extend(targetObj, obj);
console.log(targetObj);
}
) /script>
1.5. jQuery 多库共存
实际开发中,很多项目连续开发十多年,jQuery版本不断更新,最初的 jQuery 版本无法满足需求,这时就需要保证在旧有版本正常运行的情况下,新的功能使用新的jQuery版本实现,这种情况被称为,jQuery 多库共存。
语法
演示代码
script>
$(function() {
// 让jquery 释放对$ 控制权 让用自己决定 var suibian = jQuery.noConflict();
console.log(suibian("span"));
}
)/script>
相关视频教程推荐:jQuery视频教程
以上就是jquery中怎样对事件进行绑定和解绑?(代码详解)的详细内容,更多请关注其它相关文章!
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: jquery中怎样对事件进行绑定和解绑?(代码详解)
本文地址: https://pptw.com/jishu/593334.html
