JQuery不支持捕获模型

冒泡模型解析

<body>
      <div>
             <input id="bntShow" type="button" value="点击" class="bnt"/>
      </div>
      <div class="classShow">   </div>
</body>
var i = ;
$("body,div,#bntShow").click(function(){
      i++;
      $(".classShow").show().html("冒泡现象")
      .append("<div><b>执行次数"+i+"</b></div>")
});

输出结果:执行次数3

单击一次按钮却执行了3次同样的程序,$(“body,div,#bntShow”)存在冒泡现象,分别触发了#bntShow、div、body的click事件,所以执行了三次i++的操作

在JQuery中可以用stopPropagation()方法阻止冒泡

在上面的脚本中加入这句话,执行次数才能为1

$("body,div,#bntShow").click(function(){
      i++;
      $(".classShow").show().html("冒泡现象")
      .append("<div><b>执行次数"+i+"</b></div>");
      event.stopPropagation();  //还可使用return false阻止冒泡
});

事件方法

bind()                  向匹配元素附加一个或更多事件处理器

blur()                  触发、或将函数绑定到指定元素的 blur 事件

change()             触发、或将函数绑定到指定元素的 change 事件

click()                 触发、或将函数绑定到指定元素的 click 事件

dblclick()            触发、或将函数绑定到指定元素的 doubleclick 事件

delegate()          向匹配元素的当前或未来的子元素附加一个或多个事件处理器

die()                    移除所有通过live() 函数添加的事件处理程序。

error()                触发、或将函数绑定到指定元素的 error 事件

event.isDefaultPrevented()     返回 event 对象上是否调用了event.preventDefault()。

event.pageX       相对于文档左边缘的鼠标位置。

event.pageY              相对于文档上边缘的鼠标位置。

event.preventDefault()    阻止事件的默认动作。

event.result        包含由被指定事件触发的事件处理器返回的最后一个值。

event.target              触发该事件的 DOM 元素。

event.timeStamp      该属性返回从 1970 年 1 月 1 日到事件发生时的毫秒数。

event.type          描述事件的类型。

event.which        指示按了哪个键或按钮。

focus()                触发、或将函数绑定到指定元素的 focus 事件

keydown()           触发、或将函数绑定到指定元素的 key down 事件

keypress()           触发、或将函数绑定到指定元素的 key press 事件

keyup()               触发、或将函数绑定到指定元素的 key up 事件

live()                   为当前或未来的匹配元素添加一个或多个事件处理器

load()                  触发、或将函数绑定到指定元素的 load 事件

mousedown()     触发、或将函数绑定到指定元素的 mouse down 事件

mouseenter()     触发、或将函数绑定到指定元素的 mouse enter 事件

mouseleave()     触发、或将函数绑定到指定元素的 mouse leave 事件

mousemove()     触发、或将函数绑定到指定元素的 mouse move 事件

mouseout()         触发、或将函数绑定到指定元素的 mouse out 事件

mouseover()       触发、或将函数绑定到指定元素的 mouse over 事件

mouseup()          触发、或将函数绑定到指定元素的 mouse up 事件

one()                   向匹配元素添加事件处理器。每个元素只能触发一次该处理器。

ready()               文档就绪事件(当 HTML 文档就绪可用时)

resize()               触发、或将函数绑定到指定元素的 resize 事件

scroll()                触发、或将函数绑定到指定元素的 scroll 事件

select()               触发、或将函数绑定到指定元素的 select 事件

submit()              触发、或将函数绑定到指定元素的 submit 事件

toggle()                     绑定两个或多个事件处理器函数,当发生轮流的 click 事件时执行。

trigger()             所有匹配元素的指定事件

triggerHandler()       第一个被匹配元素的指定事件

unbind()              从匹配元素移除一个被添加的事件处理器

undelegate()      从匹配元素移除一个被添加的事件处理器,现在或将来

unload()              触发、或将函数绑定到指定元素的 unload 事件

bind(type,[data],function)方法

$("div").bind("clickmouseout",function(){  //绑定多个事件,可以用空格分开
      })

通过映射方法绑定

$("div").bind(
      {
             focus:function(){ },
             change:function(){ }
      }
);

带参数的情况

var message = "执行的是focus事件";
$("div").bind("focus",{msg:message},function(event){
      $("#div1").show()
      .html(event.data.msg);
})

hover()方法

此方法可以使元素在鼠标悬停和鼠标移除的事件中进行切换,该方法也可以通过mouseenter和mouseleave进行替换

$("a").hover(
      function(){ },
      function(){ }
)

等价于

$("a").mouseenter(
      function(){ };
)
$("a").mouseleave(
      function(){ };
)

toggle()方法

此方法的功能是每次单击后依次调用定义的函数

$("img").toggle(
function(){
      $("img").attr("src","imags/1.jpg");
      $("img").attr("title",this.src);
},
function(){
      $("img").attr("src","imags/2.jpg");
      $("img").attr("title",this.src);
},
function(){
      $("img").attr("src","imags/3.jpg");
      $("img").attr("title",this.src);
}
);  //单击图片,每次换一张,依次执行三个函数

unbind(type,function)方法

$("input:eq(0)").bind("click",function(){
      $("#divtip").append("按钮一的单击事件");
});
functionoClick(){
      $("#divtip").append("按钮二的单击事件");
};
$("input:eq(1)").bind("click",oClick);

$("input:eq(2)").bind("click",function(){
      $("input").unbind();  //移除全部input表单的单击事件
      //$("input").unbind("click",oClick);  //仅移除按钮二的事件
});
<input type="button" value="按钮一" class="bnt"/>
<input type="button" value="按钮二" class="bnt"/>
<input type="button" value="删除事件" class="bnt"/>
<div id="divtip"> </div>

one(type,[data],function)方法

此方法用于仅触发一次的事件绑定,用法与bind()方法类似

trigger(type,[data])方法

$("button").click(function(){
   $("input").trigger("select");
});

delegate(childSelector,event,data,function)方法

$("div").delegate("button","click",function(){
    $("p").slideToggle();
  });
<div style="background-color:red">
	<p>这是一个段落。</p>
	<button>请点击这里</button>
</div>

JQuery之事件处理的更多相关文章

  1. jQuery系列 第六章 jQuery框架事件处理

    第六章 jQuery框架事件处理 JavaScript以事件驱动来实现页面的交互,其核心是以消息为基础,以事件来驱动.虽然利用传统的JavaScript事件处理方式也能够完成页面交互,但jQuery框 ...

  2. jQuery的事件处理

    一.页面加载响应事件 $(document).ready()方法,获取文档就绪的时候.他极大地提高了Web相应速度.虽然该方法可以代替传统的window.onload()方法,但是两者之间仍然有差别. ...

  3. jQuery的事件处理方法

    .on()方法用来处理事件 $("li").on("click",function(){ $(this).addClass("complete&quo ...

  4. jQuery基础事件处理

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. jQuery基础--事件处理

    2. jQuery事件机制 JavaScript中已经学习过了事件,但是jQuery对JavaScript事件进行了封装,增加并扩展了事件处理机制.jQuery不仅提供了更加优雅的事件处理语法,而且极 ...

  6. Jquery动态绑定事件处理函数 bind / on / delegate

    1.bind方法绑定的事件处理函数不会应用到后来添加到DOM中的新元素.比如你在用bind给页面元素绑定事件之后,又新添加了一些与之前绑定过事件的元素一样的DOM元素,但是这些事件并不能在新的DOM元 ...

  7. JQuery的事件处理、Jason

    事件的处理: <body> <div id="aa" style="width:100px; height:100px; background-colo ...

  8. 使用AmplifyJS和JQuery编写更好更优雅的javascript事件处理代码

    事件(或消息)是一种经常使用的软件设计模式.可以减少消息处理者和消息公布者的之间的耦合,比方J2EE里面的JMS规范.设计模式中的观察者模式(也叫公布/订阅模式).这对于javascript代码相同适 ...

  9. jquery事件之事件处理函数

    一.事件处理 方法名 说明 语法 (events 事件类型,data数据,handler 事件处理函数,selector 选择器) Bind( 为每一个匹配元素的特定事件(像click)绑定一个事件处 ...

随机推荐

  1. ●BZOJ 1444 [Jsoi2009]有趣的游戏

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=1444题解.1: 概率dp,矩阵乘法,快速幂. 对所有串建立AC自动机, 那么如果在trie树 ...

  2. UVALive - 3882:And Then There Was One

    约瑟夫环 f[i]表示有i个人先处理第k个人,最后被处理的人是谁 #include<cstdio> #include<cstdlib> #include<algorith ...

  3. Python的序列类型——List

    List 列表 List,本质是一个链表,从链表的实现角度来讲,链表的每一个结点都存放着值和指向下一个节点的指针. 因此链表在内存的存储可以是不连续的,它是一种高效的数据结构.因此列表与字符串的区别是 ...

  4. JPA注解实体类,给表添加创建时间,更新时间,id的生成以及创建唯一约束

    首先创建一个BaseModel,自动生成创建时间和更新时间 @SuppressWarnings("serial") @MappedSuperclass public class B ...

  5. 在Unix系统中,主存索引节点和辅存索引节点从内容上比较有什么不同,为什么要设置主存索引节点?

    主存索引节点和辅存索引节点的不同主要体现在:主存索引节点状态:设备号.索引节点号:引用计数. 主存索引节点状态——反映主存索引节点的使用情况.它指示出: 1.  索引节点是否被锁上了: 2.  是否有 ...

  6. Android简单开发的画画板

    Android开发画画板要考虑得几个问题如下: 1 屏幕画板.画笔如何绘制问题 2 用户手指触摸屏幕画板监听事件,以及对应的几种状态处理问题 3  保存图片到SD卡,以及在系统相册打开时自动加载刚才的 ...

  7. MySQL 内连接与外连接

    1.内连接 MySQL中,join,cross join,inner join 是等价的. 2.外连接 2.1 左外连接 left join 2.2 右外连接  right join 3.连接条件 使 ...

  8. mybatis下使用log4j打印sql语句和执行结果

    转载自:https://www.cnblogs.com/jeevan/p/3493972.html 本来以为很简单的问题, 结果自己搞了半天还是不行; 然后google, baidu, 搜出来各种方法 ...

  9. jQuery ajax中使用serialize()方法提交表单数据示例

    <form id="form"> 输入账号 :<input id="name" type="text" name=&quo ...

  10. windows下将mysql加入环境变量

    path添加C:\program files\mysql\bin 即可