全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解jQuery中的事件

大致介绍

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的事件操作和文档操作  # 绑定  # 第二个  # 第一个  # 鼠标  # 可以使用  # 加载  # 是在  # 多个  # 自定义  # 单击  # 移除  # 当鼠标  # 也有  # 有很多  # 右键  # 如果没有  # 事件中  # 只想  # 鼠标右键  # 不支持 


相关文章: 如何在Windows环境下新建FTP站点并设置权限?  建站主机选择指南:服务器配置与SEO优化实战技巧  岳西云建站教程与模板下载_一站式快速建站系统操作指南  如何在腾讯云服务器上快速搭建个人网站?  外贸公司网站制作哪家好,maersk船公司官网?  公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?  如何在服务器上三步完成建站并提升流量?  已有域名和空间如何搭建网站?  网站制作价目表怎么做,珍爱网婚介费用多少?  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  如何在Golang中引入测试模块_Golang测试包导入与使用实践  如何在香港服务器上快速搭建免备案网站?  深入理解Android中的xmlns:tools属性  建站之星如何助力企业快速打造五合一网站?  如何快速查询域名建站关键信息?  独立制作一个网站多少钱,建立网站需要花多少钱?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  自助网站制作软件,个人如何自助建网站?  如何零基础开发自助建站系统?完整教程解析  Android自定义控件实现温度旋转按钮效果  番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?  5种Android数据存储方式汇总  建站主机默认首页配置指南:核心功能与访问路径优化  ,如何利用word制作宣传手册?  浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?  制作宣传网站的软件,小红书可以宣传网站吗?  C#如何在一个XML文件中查找并替换文本内容  香港服务器网站卡顿?如何解决网络延迟与负载问题?  如何在IIS7中新建站点?详细步骤解析  建站主机核心功能解析:服务器选择与网站搭建流程指南  网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?  网站制作说明怎么写,简述网页设计的流程并说明原因?  兔展官网 在线制作,怎样制作微信请帖?  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  ,购物网站怎么盈利呢?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  ,制作一个手机app网站要多少钱?  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  网站制作难吗安全吗,做一个网站需要多久时间?  太平洋网站制作公司,网络用语太平洋是什么意思?  怎么将XML数据可视化 D3.js加载XML  建站org新手必看:2024最新搭建流程与模板选择技巧  义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  如何通过主机屋免费建站教程十分钟搭建网站?  简易网站制作视频教程,使用记事本编写一个简单的网页html文件?  再谈Python中的字符串与字符编码(推荐)  建站上传速度慢?如何优化加速网站加载效率?  网站制作服务平台,有什么网站可以发布本地服务信息?  电脑免费海报制作网站推荐,招聘海报哪个网站多? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。