当前位置:   article > 正文

jQuery中的事件

jQuery中的事件

jQuery中的事件

jQuery事件是对JavaScript事件的封装,常用事件分类如下:

基础事件:window事件  鼠标事件  键盘事件  表单事件

复合事件(多个事件的组合):鼠标光标悬停  鼠标连续点击

1、鼠标事件

鼠标事件是当用户在文档上移动或单击鼠标时而产生的事件,常用鼠标事件有:

方法描述执行时机
click( )触发或将函数绑定到指定元素的click事件单击鼠标时
mouseover( )触发或将函数绑定到指定元素的mouse over事件鼠标移过时
mouseout( )触发或将函数绑定到指定元素的mouse out事件鼠标移出时

以mouseover()为例,实现鼠标移过时特效

  1. //当鼠标移过元素时 为事件添加响应方法
  2. $("#nav li").mouseover(function() { //当鼠标移过#nav li元素时
  3. $(this). addClass("heightlight"); //为鼠标所在li元素添加样式
  4. });
  5. $("#nav li").mouseout(function() { //当鼠标移出#nav li元素时
  6. $(this).removeClass(); //移除鼠标所在li元素的全部样式
  7. });
  8. //this指鼠标所在事件的当前元素对象

2、键盘事件

用户每次按下或者释放键盘上的键时都会产生事件,常用键盘事件有:

方法描述执行时机
keydown( )触发或将函数绑定到指定元素的keydown事件按下键盘时
keyup( )触发或将函数绑定到指定元素的keyup事件释放按键时
keypress( )触发或将函数绑定到指定元素的keypress事件产生可打印的字符时

3、表单事件

当元素获得焦点时,会触发focus事件,失去焦点时,会触发blur事件,详见下表:

方法描述执行时机
focus( )触发或将函数绑定到指定元素的focus事件获得焦点
blur( )触发或将函数绑定到指定元素的blur事件失去焦点

示例:

  1. <p>
  2. <label>用户名:</label>
  3. <input name="member" type="text" />
  4. </p>
  5. <p>
  6. <label>密码:</label>
  7. <input name="password" type="text" />
  8. </p>

获得焦点设置样式,失去焦点去除样式

  1. $(document).ready(function () {
  2. $("[name=member]").focus(function(){
  3. $(this).addClass("input_focus");
  4. });
  5. $("[name=member]").blur(function(){
  6. $(this).removeClass("input_focus");
  7. });
  8. });

二、绑定事件bind()

除了使用事件名绑定事件外,还可以使用bind()方法

1、绑定单个事件

语法:bind("事件名",函数)

"click": 事件类型 事件类型要用引号引起来

”function()“ : 处理函数

2、同时绑定多个事件方法

bind({事件名:函数,事件名:函数,.....})

  1. $("input[name=event_1]").bind({
  2. "mouseover": function () {//为mouseover绑定方法
  3. $("ul").css("display", "none");
  4. },
  5. "mouseout": function () {//为mouseout绑定方法
  6. $("ul").css("display", "block");
  7. }
  8. });

三、移除事件unbind()

参数含义描述
[type]事件类型主要包括:blur、focus、click、mouseout等基础事件,此外,还可以是 自定义事件
[fn]处理函数用来绑定的处理函数

注意:当unbind()不带参数时,表示移除所绑定的全部事件

  1. function testUnbind(){//定义一个函数移除单个事件
  2. $("input[name=userName]").unbind("mouseover");
  3. }

四、复合事件

1、鼠标光标悬停事件hover()

鼠标光标悬停事件hover()方法相当于mouseover与mouseout事件的组合

  1. $(document).ready(function() {
  2. $("#myaccound").hover(function(){//移入触发
  3. $("#menu_1").css("display","block");
  4. },
  5. function(){//光标移出时触发
  6. $("#menu_1").css("display","none");
  7. }
  8. );
  9. });

2、鼠标连续click事件

toggle()

A、用于绑定两个或多个事件处理器函数,以响应被选元素的轮流的 click 事件。

B、如果元素是可见的,切换为隐藏的;如果元素是隐藏的,切换为可见的。 toggle()方法用于模拟鼠标连续click事件(在1.9以后的版本中移除了)

  1. $(document).ready(function () {
  2. $("div[class=testToggle]").toggle(
  3. function () {
  4. $(this).css("background-color", "red");//第一次单击
  5. },
  6. function () {
  7. $(this).css("background-color", "green"); //第二次
  8. },
  9. function () {
  10. $(this).css("background-color", "blue"); //第三次
  11. }
  12. );
  13. });

感谢大家的阅读,如有不对的地方,可以私信我,感谢大家!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/很楠不爱3/article/detail/225790
推荐阅读
相关标签
  

闽ICP备14008679号