▓▓▓▓▓▓ 大致介绍

  jQuery增加了并扩展了基本的事件处理机制,不但提供了更加优雅的事件处理语法,而且极大地增强了事件处理能力

▓▓▓▓▓▓ jQuery中的事件

▓▓▓▓▓▓ 加载DOM

    在jQuery中是用$(document).ready()方法来替代JavaScript中的window.onload方法的,但是他们也有一些不同点

    1、执行时机

    例如我们有一个有很多图片的网页

    $(document).ready()方法是在这个网页的DOM树加载完就可以执行的,而window.onload方法必须在DOM树加载完和图片都加载完才执行

    如果使用jQuery我们想要在整个页面加载完在执行可以使用load()方法

    下面两段代码的功能是一样的

  1. // jQuery
  2. $(window).load(function(){
  3. // 代码1
  4. });
  5. // JavaScript
  6. window.onload = function(){
  7. // 代码2
  8. };

    2、多次使用

    JavaScript的onload事件一次只能保存对一个函数的引用,而$(document).ready()可以保存多个

  1. function one(){
  2. alert('1');
  3. }
  4.  
  5. function two(){
  6. alert('2');
  7. }
  8.  
  9. // JavaScript
  10. window.onload = one;
  11. window.onload = two;//只执行two()
  12.  
  13. // jQuery
  14. $(document).ready(function(){
  15. one();
  16. });
  17. $(document).ready(function(){
  18. two();
  19. });//one() 和 two()都会执行

    

    3、简写方式

    $(document).ready(function(){});可以简写为$(function(){});

▓▓▓▓▓▓ 事件绑定

    bind()函数的语法:bind(type,[.data],fn)

    第一个参数是事件类型

    第二个参数是可选参数,作为event.data属性值传递给事件对象的额外数据对象

    第三个参数是用来绑定的处理函数

    用例子来看,有两个div,第二个div隐藏,当我们点击第一个div时,第二个div显示

  1. <div id="div1"></div>
  2. <div id="div2"></div>
  3. <script type="text/javascript">
  4. $(function(){
  5.  
  6. $('#div1').bind('click',function(){
  7. $(this).next().show();
  8. });
  9.  
  10. });

    

    增加功能,当点击div1时如果div2是显示的,则隐藏它,否则就显示它

  1. $(function(){
  2.  
  3. $('#div1').bind('click',function(){
  4.  
  5. if($(this).next().is(':visible')){
  6. $(this).next().hide();
  7. }else{
  8. $(this).next().show();
  9. }
  10.  
  11. });
  12.  
  13. });

    简写:

  1. $('#div1').click(function(){
  2. if($(this).next().is(':visible')){
  3. $(this).next().hide();
  4. }else{
  5. $(this).next().show();
  6. }
  7.  
  8. })

▓▓▓▓▓▓ 合成事件

    1、hover()方法

    用于模拟光标悬停事件。当光标移动到元素上时触发第一个函数,当光标移出元素时,会触发第二个函数

  1. $('#div1').hover(function(){
  2. $(this).next().show();
  3. },function(){
  4. $(this).next().hide();
  5. });

    2、toggle()方法

    用于模拟鼠标连续单击事件,当鼠标第一次点击元素,触发第一个函数,当鼠标点击同一个函数时触发第二个函数

  1. $('#div1').toggle(function(){
  2. $(this).next().show();
  3. },function(){
  4. $(this).next().hide();
  5. });

▓▓▓▓▓▓ 阻止事件冒泡和阻止默认行为

    1、阻止事件冒泡

    stopPropagation()方法

    2、阻止默认行为

    preventDefault()方法

    注意:1、return false 在jQuery中是即阻止事件冒泡又阻止默认行为

         2、jQuery不支持事件捕获

▓▓▓▓▓▓ 事件对象的属性

    1、event.type

    改方法的作用是获取到事件的类型

  1. $('#div1').click(function(ev){
  2. alert(ev.type);//click
  3. })

    2、event.target

    获取到触发事件的元素

  1. $('#div1').click(function(ev){
  2. alert(ev.target.id);//div1
  3. })

    3、event.relatedTarget

    获取相关元素

    4、event.pageX和event.pageY

    获取到光标相对于页面的x的坐标和y的坐标

  1. $('#div1').click(function(ev){
  2. alert(ev.pageX + ',' + ev.pageY);//275,181
  3. })

    5、event.which

    该方法的作用是在鼠标单击事件中获取到鼠标的左、中、右键;在键盘事件中获取键盘的按键

  1. $('#div1').click(function(ev){
  2. alert(ev.which);//1是鼠标左键,2是鼠标中见,3是鼠标右键
  3. })

▓▓▓▓▓▓ 移除事件

    unbind()方法语法: unbind([type],[data]);

    第1个参数是事件类型,第2个参数是将要移除的函数

    看一个例子,为div1绑定如下事件

  1. $('#div1').bind('click',function(){
  2. alert('1');
  3. }).bind('click',function(){
  4. alert('2');
  5. }).bind('mouseover',function(){
  6. alert('3');
  7. })

    1、如果没有参数,则删除所有绑定的事件

  1. $('#div1').unbind();//删除所有事件

    2、如果提供了事件类型作为参数,则只删除该类型的绑定事件

  1. $('#div1').unbind('mouseover');//删除mouseover事件

    3、如果把绑定时传递的处理函数作为第2个参数,则只有这个特定的时间处理函数会被删除

▓▓▓▓▓▓ 模拟操作

    1、常用模拟

    在jQuery中可以使用trigger()方法完成模拟操作,例如可以使用下面的代码来触发id为btn的按钮的click事件

  1. $('#btn').trigger('click');

    

    2、触发自定义事件

    trigger()方法不仅能触发浏览器支持的具有相同名称的事件,也可以触发自定义名称的事件。

  1. $('#btn').bind('myclick',function(){
  2. alert('1');
  3. });
  4. $('#btn').trigger('myclick');

    

    3、传递数据

  1. $('#btn').bind('myclick',function(event,message1,message2){
  2. alert(message1 + message2);
  3. });
  4. $('#btn').trigger('myclick',["1","2"]);

    4、执行默认操作

  1. $('input').trigger('focus');

    以上代码会触发input元素的focus事件,也会使<input>元素本身得到焦点

    如果只想触发<input>元素上绑定的特定事件,同时取消浏览器对此事件的默认操作可以使用triggerHandler()方法

▓▓▓▓▓▓ 其他用法

    添加事件命名空间,便于管理

    例如可以把元素绑定的多个事件类型用命名空间规范起来

  1. $('div').bind('click.plugin',function(){
  2. alert('1');
  3. });
  4. $('div').bind('mouseover.plugin',function(){
  5. alert('2');
  6. });
  7. $('div').bind('dbclick.plugin',function(){
  8. alert('3');
  9. });
  10. $('button').click(function(){
  11. $('div').unbind('.plugin');
  12. })

jQuery学习之路(3)- 事件的更多相关文章

  1. jQuery学习之路(1)-选择器

    ▓▓▓▓▓▓ 大致介绍 终于开始了我的jQuery学习之路!感觉不能再拖了,要边学习原生JavaScript边学习jQuery jQuery是什么? jQuery是一个快速.简洁的JavaScript ...

  2. jquery学习笔记(三):事件和应用

    内容来自[汇智网]jquery学习课程 3.1 页面加载事件 在jQuery中页面加载事件是ready().ready()事件类似于就JavaScript中的onLoad()事件,但前者只要页面的DO ...

  3. jQuery学习小结1-CSS操作+事件

    一.DOM对象和jQuery 对象互换 1.jQuery对象 就是通过jQuery包装DOM对象后产生的对象.jQuery对象是jQuery独有的,其可以使用jQuery里的方法.比如: $(&quo ...

  4. jQuery 学习之路(4):事件

    一.文档载入事件 二.事件绑定 三.事件对象 四.浏览器事件 五.表单事件 六.键盘事件 七.鼠标事件

  5. jQuery学习之路(8)- 表单验证插件-Validation

    ▓▓▓▓▓▓ 大致介绍 jQuery Validate 插件为表单提供了强大的验证功能,让客户端表单验证变得更简单,同时提供了大量的定制选项,满足应用程序各种需求.该插件捆绑了一套有用的验证方法,包括 ...

  6. jQuery学习之路(7)- 用原生JavaScript实现jQuery的某些简单功能

    ▓▓▓▓▓▓ 大致介绍 学习了妙味,用原生的JavaScript实现jQuery中的某些部分功能 定义自己的函数库lQuery ▓▓▓▓▓▓ $()选择器的实现 jQuery是面向对象的,所以自己编写 ...

  7. jQuery 学习之路(1):引子

    一.主流 javascript 库 除 jQuery 外,还有 Prototype.Dojo.YUI.ExtJS.MooTools ,其中 Prototype 较老,结构设计较为松散,ExtJS 界面 ...

  8. jQuery学习之路(6)- 简单的表格应用

    ▓▓▓▓▓▓ 大致介绍 在CSS技术之前,网页的布局基本都是依靠表格制作,当有了CSS之后,表格就被很多设计师所抛弃,但是表格也有他的用武之地,比如数据列表,下面以表格中常见的几个应用来加深对jQue ...

  9. jQuery学习之路(2)-DOM操作

    ▓▓▓▓▓▓ 大致介绍 jQuery作为JavaScript库,继承并发扬了JavaScript对DOM对象操作的特性,使开发人员能方便的操作DOM对象. ▓▓▓▓▓▓ jQuery中的DOM操作 看 ...

随机推荐

  1. Hyper-V2:向VM增加虚拟硬盘

    使用Hyper-V创建VM,在VM成功安装OS之后,发现VM只有一个逻辑盘C,用于存储VM的操作系统.在产品环境中,需要向VM增加虚拟硬盘,便于将数据单独存储在不同的逻辑盘符中.在Hyper-V中,分 ...

  2. PHP好用但又容易忽略的小知识

    1.PHP函数之判断函数是否存在 当我们创建了自定义函数,并且了解了可变函数的用法,为了确保程序调用的函数是存在的,经常会先使用function_exists判断一下函数是否存在.同样的method_ ...

  3. Kafka副本管理—— 为何去掉replica.lag.max.messages参数

    今天查看Kafka 0.10.0的官方文档,发现了这样一句话:Configuration parameter replica.lag.max.messages was removed. Partiti ...

  4. GJM : C#设计模式汇总整理——导航 【原创】

    感谢您的阅读.喜欢的.有用的就请大哥大嫂们高抬贵手"推荐一下"吧!你的精神支持是博主强大的写作动力以及转载收藏动力.欢迎转载! 版权声明:本文原创发表于 [请点击连接前往] ,未经 ...

  5. Angular (SPA) WebPack模块化打包、按需加载解决方案完整实现

    文艺小说-?2F,言情小说-?3F,武侠小说-?9F long long ago time-1-1:A 使用工具,long long A ago time-1-2:A 使用分类工具,long long ...

  6. Android listview和gridview以及view的区别

    GridView 可以指定显示的条目的列数. listview一般显示的条目的列数都是一列 如果是列表(单列多行形式)的使用ListView,如果是多行多列网状形式的优先使用GridView andr ...

  7. mysql源码包手动安装、配置以及测试(亲测可行)

    笔记编者:小波/qq463431476博客首页:http://www.cnblogs.com/xiaobo-Linux/ 记下这篇mysql笔记,望日后有用! redhat6采用centos yum源 ...

  8. SSD框架训练自己的数据集

    SSD demo中详细介绍了如何在VOC数据集上使用SSD进行物体检测的训练和验证.本文介绍如何使用SSD实现对自己数据集的训练和验证过程,内容包括: 1 数据集的标注2 数据集的转换3 使用SSD如 ...

  9. AutoMapper(五)

    返回总目录 Dynamic和ExpandoObject映射 AutoMapper不用任何配置就可以从dynamic(动态)对象映射或映射到dynamic对象. namespace FifthAutoM ...

  10. 集成基于CAS协议的单点登陆

    相信大家对单点登陆(SSO,Single Sign On)这个名词并不感到陌生吧?简单地说,单点登陆允许多个应用使用同一个登陆服务.一旦一个用户登陆了一个支持单点登陆的应用,那么在进入其它使用同一单点 ...