js事件防止冒泡

js事件防止冒泡

大家好,又见面了,我是全栈君。

原文连接:http://www.cnblogs.com/jams742003/archive/2009/08/29/1556187.html

1. 事件目标

如今。事件处理程序中的变量event保存着事件对象。而event.target属性保存着发生事件的目标元素。这个属性是DOM API中规定的,可是没有被全部浏览器实现 

jQuery对这个事件对象进行了必要的扩展,从而在不论什么浏览器中都能够使用这个属性。通过.target,能够确定DOM中首先接收到事件的元素(即实际被单击的元素)。

并且,我们知道this引用的是处理事件的DOM元素,所以能够编写下列代码:
$(document).ready(function(){
 $(‘#switcher’).click(function(event){
  $(‘#switcher .button’).toggleClass(‘hidden’);
  })
 })
  
$(document).ready(function(){
 $(‘#switcher’).click(function(event){
  if(event.target==this){
  $(‘#switcher .button’).toggleClass(‘hidden’);
  }
  })
 })
此时的代码确保了被单击的元素是<div id=”switcher”> ,而不是其它后代元素。如今,单击button不会再折叠样式转换器。而单击边框则会触发折叠操作。可是,单击标签相同什么也不会发生,由于它也是一个后代元素。实际上。我们能够不把检查代码放在这里,而是通过改动button的行为来达到目标 

2. 停止事件传播

事件对象还提供了一个.stopPropagation()方法,该方法能够全然阻止事件冒泡。与.target类似,这种方法也是一种纯JavaScript特性,但在跨浏览器的环境中则无法安全地使用 

只是,仅仅要我们通过jQuery来注冊全部的事件处理程序。就能够放心地使用这种方法。

以下。我们会删除刚才加入的检查语句event.target == this。并在button的单击处理程序中加入一些代码:

$(document).ready(function(){
 $(‘#switcher .button’).click(funtion(event){
  //……
   event.stopPropagation();
  })
 }) 

  同曾经一样,须要为用作单击处理程序的函数加入一个參数。以便訪问事件对象。然后。通过简单地调用event.stopPropagation()就能够避免其它全部DOM元素响应这个事件。这样一来,单击button的事件会被button处理。并且仅仅会被button处理。

单击样式转换器的其它地方则能够折叠和扩展整个区域。

3. 默认操作

假设我们把单击事件处理程序注冊到一个锚元素,而不是一个外层的<div>上,那么就要面对另外一个问题:当用户单击链接时。浏览器会载入一个新页面。这样的行为与我们讨论的事件处理程序不是同一个概念,它是单击锚元素的默认操作。类似地,当用户在编辑完表单后按下回车键时。会触发表单的submit事件,在此事件发生后,表单提交才会真正发生。

假设我们不希望运行这样的默认操作。那么在事件对象上调用.stopPropagation()方法也无济于事,由于默认操作不是在正常的事件传播流中发生的。

在这样的情况下,.preventDefault()方法则能够在触发默认操作之前终止事件 

提示 当在事件的环境中完毕了某些验证之后,一般会用到.preventDefault()。比如。在表单提交期间。我们会对用户是否填写了必填字段进行检查。假设用户没有填写对应字段,那么就须要阻止默认操作。我们将在第8章具体讨论表单验证。

事件传播和默认操作是相互独立的两套机制,在二者不论什么一方发生时,都能够终止还有一方。假设想要同一时候停止事件传播和默认操作,能够在事件处理程序中返回false。这是对在事件对象上同一时候调用.stopPropagation().preventDefault()的一种简写方式。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/115637.html原文链接:https://javaforall.net

(0)
上一篇 2022年2月1日 下午6:00
下一篇 2022年2月1日 下午6:00


相关推荐

  • CheckedListBox 当中项的状态改变

    CheckedListBox 当中项的状态改变首先 说下我需要实现的功能 就是把获得数据 Id 显示在 CheckedListB 上 单击空白处不响应 如果在 CheckedListB 上勾选的项就加入到 list 集合中 取消勾选状态就从集合中移除 之前我碰到一个问题 如图 我采用 SelectedInde 和 MouseClick 事件 都不能解决我碰到的问题 解决办法 nbsp voidlstMotes ItemChe

    2026年3月18日
    2
  • 谷歌 Chrome 浏览器接入 Gemini AI:能帮你解读网页、模糊检索历史记录

    谷歌 Chrome 浏览器接入 Gemini AI:能帮你解读网页、模糊检索历史记录

    2026年3月16日
    1
  • Qt Creator的下载和安装

    Qt Creator的下载和安装Qt和QtCreator的区别Qt是C++的一个库,或者说是开发框架,里面集成了一些库函数,提高开发效率。QtCreator是一个IDE,就是一个平台,一个开发环境,类似的比如说VS,也可以进行Qt开发,当然VS中的Qt是作为一个插件插入VS平台的。下载QtCreator下载地址1:https://www.qt.io/download这是官网下载地址,选择开源opensou…

    2022年5月16日
    41
  • javascript 数据类型

    javascript 数据类型js 真是一门有趣的语言 在 js 的世界中 数据有两种类型 一种是引用类型 一种是基本数据类型引用类型 在 js 的世界里 有一句话 所有的一切 都是 object 那么问题来了 object 是基本数据还是引用类型的呢 嘿嘿 卖个关子 后面再讲 先来讲讲对于引用类型的定义 引用类型值则是指那些保存在堆内存中的对象 意思是变量中保存的实际上只是一个指针 这个指针指向内存中的

    2026年3月18日
    2
  • 多项式分布的理解概率公式的理解「建议收藏」

    多项式分布的理解概率公式的理解「建议收藏」多项式分布是二项分布的推广。二项分布(也叫伯努利分布)的典型例子是扔硬币,硬币正面朝上概率为p,重复扔n次硬币,k次为正面的概率即为一个二项分布概率。而多项分布就像扔骰子,有6个面对应6个不同的点数。二项分布时事件X只有2种取值,而多项分布的X有多种取值,多项分布的概率公式为  这个公式看上去像是莫名其妙地冒出来的,想要了解它首先必须要知道组合数学中的多项式定理。多项式定理:当n是一个正整数时…

    2022年10月12日
    5
  • linux脚本跳出循环语句,跳出循环的命令

    linux脚本跳出循环语句,跳出循环的命令1 exit 退出循环 同时也会退出脚本 root shell scripts shell day31 catexit sh bin bashforiin 1 3 doecho 123 exitecho 456 doneecho 脚本执行结束 root shell scripts shell day31 shexit sh1232 break

    2025年10月26日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号