详解jQuery中的事件
发布时间 - 2026-01-10 21:49:47 点击率:次大致介绍

jQuery增加了并扩展了基本的事件处理机制,不但提供了更加优雅的事件处理语法,而且极大地增强了事件处理能力
jQuery中的事件
加载DOM
在jQuery中是用$(document).ready()方法来替代JavaScript中的window.onload方法的,但是他们也有一些不同点
1、执行时机
例如我们有一个有很多图片的网页
$(document).ready()方法是在这个网页的DOM树加载完就可以执行的,而window.onload方法必须在DOM树加载完和图片都加载完才执行
如果使用jQuery我们想要在整个页面加载完在执行可以使用load()方法
下面两段代码的功能是一样的
// jQuery
$(window).load(function(){
// 代码1
});
// JavaScript
window.onload = function(){
// 代码2
};
2、多次使用
JavaScript的onload事件一次只能保存对一个函数的引用,而$(document).ready()可以保存多个
function one(){
alert('1');
}
function two(){
alert('2');
}
// JavaScript
window.onload = one;
window.onload = two;//只执行two()
// jQuery
$(document).ready(function(){
one();
});
$(document).ready(function(){
two();
});//one() 和 two()都会执行
3、简写方式
$(document).ready(function(){});可以简写为$(function(){});
事件绑定
bind()函数的语法:bind(type,[.data],fn)
第一个参数是事件类型
第二个参数是可选参数,作为event.data属性值传递给事件对象的额外数据对象
第三个参数是用来绑定的处理函数
用例子来看,有两个div,第二个div隐藏,当我们点击第一个div时,第二个div显示
<div id="div1"></div>
<div id="div2"></div>
<script type="text/javascript">
$(function(){
$('#div1').bind('click',function(){
$(this).next().show();
});
});
增加功能,当点击div1时如果div2是显示的,则隐藏它,否则就显示它
$(function(){
$('#div1').bind('click',function(){
if($(this).next().is(':visible')){
$(this).next().hide();
}else{
$(this).next().show();
}
});
});
简写:
$('#div1').click(function(){
if($(this).next().is(':visible')){
$(this).next().hide();
}else{
$(this).next().show();
}
})
合成事件
1、hover()方法
用于模拟光标悬停事件。当光标移动到元素上时触发第一个函数,当光标移出元素时,会触发第二个函数
$('#div1').hover(function(){
$(this).next().show();
},function(){
$(this).next().hide();
});
2、toggle()方法
用于模拟鼠标连续单击事件,当鼠标第一次点击元素,触发第一个函数,当鼠标点击同一个函数时触发第二个函数
$('#div1').toggle(function(){
$(this).next().show();
},function(){
$(this).next().hide();
});
阻止事件冒泡和阻止默认行为
1、阻止事件冒泡
stopPropagation()方法
2、阻止默认行为
preventDefault()方法
注意:1、return false 在jQuery中是即阻止事件冒泡又阻止默认行为
2、jQuery不支持事件捕获
事件对象的属性
1、event.type
改方法的作用是获取到事件的类型
$('#div1').click(function(ev){
alert(ev.type);//click
})
2、event.target
获取到触发事件的元素
$('#div1').click(function(ev){
alert(ev.target.id);//div1
})
3、event.relatedTarget
获取相关元素
4、event.pageX和event.pageY
获取到光标相对于页面的x的坐标和y的坐标
$('#div1').click(function(ev){
alert(ev.pageX + ',' + ev.pageY);//275,181
})
5、event.which
该方法的作用是在鼠标单击事件中获取到鼠标的左、中、右键;在键盘事件中获取键盘的按键
$('#div1').click(function(ev){
alert(ev.which);//1是鼠标左键,2是鼠标中见,3是鼠标右键
})
移除事件
unbind()方法语法: unbind([type],[data]);
第1个参数是事件类型,第2个参数是将要移除的函数
看一个例子,为div1绑定如下事件
$('#div1').bind('click',function(){
alert('1');
}).bind('click',function(){
alert('2');
}).bind('mouseover',function(){
alert('3');
})
1、如果没有参数,则删除所有绑定的事件
$('#div1').unbind();//删除所有事件
2、如果提供了事件类型作为参数,则只删除该类型的绑定事件
$('#div1').unbind('mouseover');//删除mouseover事件
3、如果把绑定时传递的处理函数作为第2个参数,则只有这个特定的时间处理函数会被删除
模拟操作
1、常用模拟
在jQuery中可以使用trigger()方法完成模拟操作,例如可以使用下面的代码来触发id为btn的按钮的click事件
$('#btn').trigger('click');
2、触发自定义事件
trigger()方法不仅能触发浏览器支持的具有相同名称的事件,也可以触发自定义名称的事件。
$('#btn').bind('myclick',function(){
alert('1');
});
$('#btn').trigger('myclick');
3、传递数据
$('#btn').bind('myclick',function(event,message1,message2){
alert(message1 + message2);
});
$('#btn').trigger('myclick',["1","2"]);
4、执行默认操作
$('input').trigger('focus');
以上代码会触发input元素的focus事件,也会使<input>元素本身得到焦点
如果只想触发<input>元素上绑定的特定事件,同时取消浏览器对此事件的默认操作可以使用triggerHandler()方法
其他用法
添加事件命名空间,便于管理
例如可以把元素绑定的多个事件类型用命名空间规范起来
$('div').bind('click.plugin',function(){
alert('1');
});
$('div').bind('mouseover.plugin',function(){
alert('2');
});
$('div').bind('dbclick.plugin',function(){
alert('3');
});
$('button').click(function(){
$('div').unbind('.plugin');
})
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# jquery
# 事件
# 基于jQuery的select下拉框选择触发事件实例分析
# jQuery绑定事件的四种方式介绍
# 浅谈jquery之on()绑定事件和off()解除绑定事件
# jquery移除了live()、die()
# 新版事件绑定on()、off()的方法
# jquery文档操作wrap()方法实例简述
# Lazy Load 延迟加载图片的jQuery插件中文使用文档
# jQuery EasyUI API 中文文档 - TreeGrid 树表格使用介绍
# jQuery EasyUI API 中文文档 - Tree树使用介绍
# jQuery EasyUI API 中文文档 - DataGrid数据表格
# 详解Jquery的事件操作和文档操作
# 绑定
# 第二个
# 第一个
# 鼠标
# 可以使用
# 加载
# 是在
# 多个
# 自定义
# 单击
# 移除
# 当鼠标
# 也有
# 有很多
# 右键
# 如果没有
# 事件中
# 只想
# 鼠标右键
# 不支持
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251811 】
【
AI营销90571 】
相关推荐:
怎么用AI帮你为初创公司进行市场定位分析?
Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置
如何在腾讯云服务器上快速搭建个人网站?
JS实现鼠标移上去显示图片或微信二维码
如何在橙子建站中快速调整背景颜色?
Laravel如何正确地在控制器和模型之间分配逻辑_Laravel代码职责分离与架构建议
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
网站建设保证美观性,需要考虑的几点问题!
php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
在Oracle关闭情况下如何修改spfile的参数
laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程
php增删改查怎么学_零基础入门php数据库操作必知基础【教程】
想要更高端的建设网站,这些原则一定要坚持!
bing浏览器学术搜索入口_bing学术文献检索地址
Laravel如何使用Livewire构建动态组件?(入门代码)
如何基于云服务器快速搭建网站及云盘系统?
Laravel如何编写单元测试和功能测试?(PHPUnit示例)
中山网站制作网页,中山新生登记系统登记流程?
Win11关机界面怎么改_Win11自定义关机画面设置【工具】
Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程
Laravel如何集成Inertia.js与Vue/React?(安装配置)
Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
网站页面设计需要考虑到这些问题
laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法
Python文件异常处理策略_健壮性说明【指导】
ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
php485函数参数是什么意思_php485各参数详细说明【介绍】
详解Android图表 MPAndroidChart折线图
laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
海南网站制作公司有哪些,海口网是哪家的?
北京网站制作公司哪家好一点,北京租房网站有哪些?
如何用y主机助手快速搭建网站?
Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法
Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
Laravel如何实现API资源集合?(Resource Collection教程)
香港服务器租用每月最低只需15元?
如何获取免费开源的自助建站系统源码?
Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)
ChatGPT 4.0官网入口地址 ChatGPT在线体验官网
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】
Laravel如何实现邮件验证激活账户_Laravel内置MustVerifyEmail接口配置【步骤】
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
Laravel如何使用模型观察者?(Observer代码示例)

