jQuery事件绑定与反绑定,模仿鼠标悬停,事件对象

本文主要是介绍jQuery事件绑定与反绑定,模仿鼠标悬停,事件对象,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

页面载入事件

事件绑定

绑定事件的函数   

jQuery事件处理函数的好处

反绑定事件

事件绑定和反绑定的实例

一次性的事件绑定

模仿鼠标悬停事件

jQuery事件对象


页面载入事件

1、JavaScript的页面载入事件:window.onload

缺点:通过这个方法,用户可以设定一些特定的操作,让其在页面的DOM树加载完毕之后执行,但是浏览器执行window.onload函数不仅仅是在构建完DOM树之后, 也是在所有图像和其他外部资源完整的加载并且在浏览器窗口显示完毕之后. 所以如果某个图片或者其他资源加载很长时间, 访问者就会看到一个不完整的页面, 甚至在图片加载之前就执行了需要依赖动态添加的元素的脚本而导致脚本错误。

解决方法:等DOM被解析后, 在图像和外部资源加载之前执行我们的函数。

2、 jQuery的页面载入事件(入口函数):$(function(){ js代码 })

事件绑定

一个事件的响应本身可能实现为一个函数,但是真正要使其得到执行,还需要将其与相应的元素动作绑定到一起。

所谓绑定,其实就是将页面元素的事件类型与其在收到该事件之后期望进行的操作联系到一起。例如经常提到的“当我们单击这个按钮的时候,就会执行某些动作”,让这里的“单击”动作与“执行某些动作”连接到一起的操作就是绑定了。

绑定事件的函数   

该函数将为调用它的每个匹配元素的特定事件绑定一个事件处理函数。它最多可以有三个参数,其中事件类型和处理函数为必选参数。

//绑定事件的函数 
$(selector).bind('事件类型',function(){处理代码
})       
//另一种写法
$(selector).事件名(function(){处理代码
})
函数名bind(type,[data],fn)
作用为每一个匹配元素的特定事件(像click)绑定一个事件处理器函数
返回值Object
参数

type(String):事件类型

data (Object):(可选)作为event.data属性值传递给事件对象的额外数据对象

fn ( Function):绑定到每个匹配元素的事件上面的处理函数

例如:$("#testDiv4").bind("click", showMsg); 

为id是testDiv4的元素, 添加列click事件的事件处理函数showMsg.

jQuery事件处理函数的好处

  • 添加的是多播事件委托. 。也就是为click事件又添加了一个方法, 不会覆盖对象的click事件原有的事件处理函数。
  • 统一了事件名称。
  • 可以将对象行为全部用脚本控制。让HTML代码部分只注意"显示"逻辑,是将HTML的行为, 内容与样式切分干净.。其中用脚本控制元素行为, 用HTML标签控制元素内容, 用CSS控制元素样式.。使用jQuery事件处理函数可以避免在HTML标签上直接添加事件。

反绑定事件

在对一个元素绑定了某种事件类型之后,可能在后来的某个时刻不再希望让该元素监听该类型的事件,此时就需要反绑定。所谓反绑定,就是解除与元素绑定的某种事件类型及处理函数。jQuery中的反绑定处理函数为unbind([type],[data])函数。

函数名unbind([type],[data])
作用bind()的反向操作,从每一个匹配的元素中删除绑定的事件。如果没有参数,则删除所有绑定的事件。可以将用户用bind()注册的自定义事件取消绑定。如果提供了事件类型作为参数,则只删除该类型的绑定事件
返回值Object
参数

type(String):(可选)事件类型

data (Function):(可选)要从每个匹配元素的事件中反绑定的事件处理函数

事件绑定和反绑定的实例

分析:点击提交则会把输入的用户名和密码提交至客户端,点击重置则会使其清空,为重置创建反绑定事件,则再次点击重置时不会清除内容。

<body style="text-align: center;"><div style="margin-top: 3px;"><label>用户名:<input type="text" id="username"></label><br><br><label>密码:<input type="password" id="pwd"></label><br><br><button type="button" id="btn_ok">提交</button>&nbsp;&nbsp;&nbsp;&nbsp;<button type="button" id="btn_reset">重置</button></div><script>$(function(){//给“重置”按钮绑定click事件$('#btn_reset').bind('click',function(){$('#username').val('')  //设置id为username的按钮的值为空$('#pwd').val('')})//给“提交”按钮绑定click事件$('#btn_ok').bind('click',function(){var n = $('#username').val()  //获取id为username的按钮的值var p = $('#pwd').val()console.log("用户名:"+n)console.log("密码:"+p)})//取消“重置”按钮的click事件$('#btn_reset').unbind('click')})</script>
</body>

一次性的事件绑定

一次性的事件绑定,是指与元素绑定的事件只能被使用一次,也就是说在触发一次之后即便再执行该类型的事件也不会去执行对应的处理函数。

函数名one(type,[data],fn)
作用为每一个匹配元素的特定事件(像click)绑定一个一次性的事件处理函数。在每个对象上,这个事件处理函数只会被执行一次。其他规则与bind()函数相同。
返回值Object
参数

type(String):事件类型

data (Object):(可选)作为event.data属性值传递给事件对象的额外数据对象

fn ( Function):绑定到每个匹配元素的事件上面的处理函数

实例当所有段落被第一次点击的时候,显示所有其文本:
$("p").one("click", function(){
     alert( $(this).text() );
});

模仿鼠标悬停事件

$(selector).hover(over,out)

    over:回调函数,表示鼠标悬停时调用的函数

    out:回调函数,表示鼠标离开时调用的函数

实例:当鼠标放在一张图片上时显示另一张图片,移开后显示原图片

<body><img src="../images/5.jpg" width="300" height="300"><script>$(function(){$('img').hover(function(evenr){$('img').attr('src','../images/3.jpg')console.log(event.type)},function(){$('img').attr('src','../images/5.jpg')console.log(event.type)})})</script>
</body>

jQuery事件对象

jQuery中统一了事件对象,  当绑定事件处理函数时,  会将jQuery格式化后的事件对象作为唯一参数传入。  

例如      $(selector).bind('click',function(event){  -->'event'代表jQuery的事件对象
                   处理代码
              })

(1)type:事件类型

(2)target:事件对象,获取事件触发者DOM对象

(3)pageXpageY:在鼠标事件中鼠标相对于页面原点的x、y坐标

这篇关于jQuery事件绑定与反绑定,模仿鼠标悬停,事件对象的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/806506

相关文章

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

java中VO PO DTO POJO BO DO对象的应用场景及使用方式

《java中VOPODTOPOJOBODO对象的应用场景及使用方式》文章介绍了Java开发中常用的几种对象类型及其应用场景,包括VO、PO、DTO、POJO、BO和DO等,并通过示例说明了它... 目录Java中VO PO DTO POJO BO DO对象的应用VO (View Object) - 视图对象

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

Java将时间戳转换为Date对象的方法小结

《Java将时间戳转换为Date对象的方法小结》在Java编程中,处理日期和时间是一个常见需求,特别是在处理网络通信或者数据库操作时,本文主要为大家整理了Java中将时间戳转换为Date对象的方法... 目录1. 理解时间戳2. Date 类的构造函数3. 转换示例4. 处理可能的异常5. 考虑时区问题6.

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

Python中的异步:async 和 await以及操作中的事件循环、回调和异常

《Python中的异步:async和await以及操作中的事件循环、回调和异常》在现代编程中,异步操作在处理I/O密集型任务时,可以显著提高程序的性能和响应速度,Python提供了asyn... 目录引言什么是异步操作?python 中的异步编程基础async 和 await 关键字asyncio 模块理论

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️