首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【Web前端】嵌套元素的“事件”冒泡?!

事件冒泡是指在嵌套的 HTML 元素中,一个事件从最具体的元素开始,然后向上传播到更高层级的父元素。...例如,如果用户点击一个嵌套的按钮,事件首先会被按钮捕获,然后会冒泡到按钮的父元素,接着是父元素的父元素,直到到达 ​​​​​ 元素或文档的根元素。...然后,事件冒泡到父 ​​div​​,触发 父元素点击事件。 如果我们想要控制这一流程,可以使用 ​​stopPropagation()​​​ 方法。...因为这里的事件监听器是以捕获模式添加的,父元素的监听器在子元素之前被触发。 事件捕获和冒泡的总结 事件冒泡从具体元素到父元素。 事件捕获从父元素到具体元素。 默认情况下,事件是以冒泡的方式处理的。...事件冒泡和捕获是浏览器处理事件的重要机制。实际开发中: 事件冒泡可以让我们轻松处理嵌套元素的事件。 通过调用 ​​stopPropagation()​​ 你可以精确地控制事件流。

7300
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    HTML的元素嵌套规则

    一般用在网站内容之中的某些细节或部位,用以“强调、区分样式、上标、下标、锚点”等等,下面这些标签都属于内嵌元素:   a、abbr、acronym、b、bdo、big、br、cite、code、dfn、...i、img、input、kbd、label、q、s、samp、select、small、span、strike、strong、sub、sup、textarea、tt、u、var   二、HTML 标签的嵌套规则...块元素可以包含内联元素或某些块元素,但内联元素却不能包含块元素,它只能包含其它的内联元素:    —— 对   ...有几个特殊的块级元素只能包含内嵌元素,不能再包含块级元素,这几个特殊的标签是:   h1、h2、h3、h4、h5、h6、p、dt   4. li 内可以包含 div 标签 —— 这一条其实不必单独列出来的...,但是网上许多人对此有些疑惑,就在这里略加说明:   li 和 div 标 签都是装载内容的容器,地位平等,没有级别之分(例如:h1、h2 这样森严的等级制度^_^),要知道,li 标签连它的父级 ul

    2.6K20

    riot.js教程【五】标签嵌套、命名元素、事件、标签条件

    方法传递的,子标签的参数是通过标签属性传递过去的 注意:嵌套的标签总是在父标签内部声明,定义; 标签内嵌入HTML 我们先定义一个my-tag标签 Hello 的,其实是text变量 这就是在标签内嵌入HTML代码 命名元素 当元素具备ref属性的时候, 这个元素会被链接到this.refs上, 这样你就可以很方便的用JS访问到它 事件被触发前完成的,所以你可以在mount事件中访问到this.refs 事件 DOM事件可以直接和riotjs标签内的方法绑定,示例如下: 事件; 方法的第一个参数就是标准的event对象 e.currentTarget 指代触发事件的DOM元素 e.target 也指代触发事件的DOM...,相当于 style="display: none" if – 当值是true的时候,会把该标签加入到DOM元素中,是false的时候,不会把标签加入到dom元素中

    3.9K80

    input元素的oninput事件和onchange事件

    input元素的oninput事件和onchange事件 框架用多了,感觉原生的有点弱化了,不说了,是时候巩固一波了 ^ _ ^ 1、input元素上绑定事件的三种方式: 第一种:直接在元素标签上添加oninput...) { // 处理事件代码 } 第二种:获取input元素,然后在元素对象上添加oninput属性,属性值为函数,函数内部为处理事件函数的调用 <input type="text" id="...} 第三种:获取input元素,然后在元素上利用事件监听添加input事件 var inputEle = document.querySelector...2、input元素的oninput事件和onchange事件的区别 oninput事件是在输入框中输入时就会触发 onchange事件是在输入框输入完内容后,输入框失焦后触发 onchange事件兼容性好...,主流浏览器都支持 oninput事件IE9以下不支持,其余主流浏览器都支持,针对IE9以下的可以使用onpropertychange事件来替代 参考文献: [1] oninput 事件 [2] input

    3.5K10

    react中的事件绑定

    React中的事件绑定是将事件处理函数与组件的交互操作关联起来的过程。通过事件绑定,我们可以在React组件中响应用户的交互,并进行相应的操作。...React中的事件绑定特点React中的事件绑定具有以下特点:以驼峰命名:React中的事件名采用驼峰命名方式,如onClick、onChange等。...以下是一个简单的示例,展示了如何绑定一个点击事件:import React from 'react';class Button extends React.Component { handleClick...使用事件对象在事件处理函数中,可以通过参数获取事件对象,并从中获取相关信息,如事件的类型、目标元素等。...onClick属性中传递了一个事件对象,并在handleClick方法中使用event.type和event.target来获取事件的类型和目标元素。

    3.1K30

    React基础(7)-React中的事件处理

    那么本篇就是你想要知道的 React中的事件 在React中事件的绑定是直接写在JSX元素上的,不需要通过addEventListener事件委托的方式进行监听 写法上: 在JSX元素上添加事件,通过...on*EventType这种内联方式添加,命名采用小驼峰式(camelCase)的形式,而不是纯小写(原生HTML中对DOM元素绑定事件,事件类型是小写的),无需调用addEventListener进行事件监听...,如下图所示 image.png 当给DOM元素绑定了事件处理函数的时候,该函数会自动的传入一个event对象,这个对象和普通的浏览器的对象记录了当前事件的属性和方法 在React中,event对象并不是浏览器提供的...= this.handleDelete.bind(this); } 解决事件处理函数每次被重复渲染的问题 在Es5中,当调用一个函数时,函数名往往要加上一个圆括号,而在JSX 中给React元素绑定事件处理函数时...)的例子: 高频事件就像是一个大开的水龙头,水流源源不断的大量流出,就像代码在不断的执行,若不加以控制,就会造成资源的一种浪费 对应页面中的,若是表单中连续点击提交按钮,监听滚动事件,连续下拉加载等请求服务器的资源

    8.4K41

    React学习(七)-React中的事件处理

    那么本篇就是你想要知道的 React中的事件 在React中事件的绑定是直接写在JSX元素上的,不需要通过addEventListener事件委托的方式进行监听 写法上: 在JSX元素上添加事件,通过...on*EventType这种内联方式添加,命名采用小驼峰式(camelCase)的形式,而不是纯小写(原生HTML中对DOM元素绑定事件,事件类型是小写的),无需调用addEventListener进行事件监听...当给DOM元素绑定了事件处理函数的时候,该函数会自动的传入一个event对象,这个对象和普通的浏览器的对象记录了当前事件的属性和方法 在React中,event对象并不是浏览器提供的,你可以将它理解为React...= this.handleDelete.bind(this); } 解决事件处理函数每次被重复渲染的问题 在Es5中,当调用一个函数时,函数名往往要加上一个圆括号,而在JSX 中给React元素绑定事件处理函数时...)的例子: 高频事件就像是一个大开的水龙头,水流源源不断的大量流出,就像代码在不断的执行,若不加以控制,就会造成资源的一种浪费 对应页面中的,若是表单中连续点击提交按钮,监听滚动事件,连续下拉加载等请求服务器的资源

    7.4K40

    form 元素是 React 的未来

    Next.js的发展历程 说到React未来的发展,必须从Next.js聊起。毕竟,React团队成员不是加入Next团队,就是在加入的路上。...Server Action 「根据前端用户输入保存数据到后端」的常见场景是「表单提交」,通常我们会在form的onSubmit事件中做后续处理: function Form() { function...目标1 HTML原生的form元素有个action属性,可以接收一个url。当提交表单(比如点击type为submit的按钮)后formData会提交给该url。...实际上,为了实现useFormStatus,React在源码内为所有HostComponent(即原生HTML元素对应组件,比如)定制了一个context。...server action是Next.js的未来,Next.js是React的未来。所以,React的未来会围绕form元素持续布局。

    35930

    jQuery 查找on事件绑定元素的被绑定元素方法

    jQuery 查找on事件绑定元素的被绑定元素方法 遇到的问题 今天写了一个JQ插件,结果里面有一点问题.让我很郁闷.问题演示代码如下 $box.on('click', 'img', function(...){ $(this) }); 如上代码,当我点击这个图片的时候 $(this) 是指 img ....当然这是正确的. 而我需要找到 $box 也就是 img 的父级. 如果不是插件的话,我当然可以根据它的ID或者CLASS来进行查询.问题是,我是写的插件,也就是说,我并不知道它的这些信息是什么....解决方法 很多基础的东西不理解,就会出现我这样的问题.如同事所说,你是还不会爬呢,都学上跑了.因此,踩坑无数啊....解决方法如下: $box.on('click', 'img', function(){ $box.has($(this)) }); 如上,通过 .has 操作,就能找到唯一的父级被绑定元素了.

    4.5K10

    react中的事件处理(二)

    使用State在React中,事件处理函数通常会与组件的状态(state)进行交互。我们可以通过更新状态来响应事件的发生。...以下是一个示例,展示了如何在事件处理函数中更新组件的状态:import React from 'react';class MyComponent extends React.Component { constructor...我们使用setState方法传递一个回调函数,该回调函数接收前一个状态作为参数,并返回一个新的状态对象。阻止事件冒泡和默认行为在某些情况下,我们可能希望阻止事件冒泡或阻止事件的默认行为。...以下是一个示例,展示了如何阻止事件冒泡和阻止默认行为:import React from 'react';class MyComponent extends React.Component { handleButtonClick...在handleButtonClick方法中,我们使用event.stopPropagation()阻止了事件冒泡,以及使用event.preventDefault()阻止了按钮的默认行为。

    82020

    react中的事件处理(一)

    事件绑定React中的事件绑定采用了类似于HTML中的方式,但有一些语法上的差异。我们可以在组件中定义事件处理函数,并将其绑定到特定的事件上。...以下是一个示例,展示了如何在React中进行事件绑定:import React from 'react';class MyComponent extends React.Component { handleClick...我们使用onClick属性将handleClick方法绑定到按钮的点击事件上。需要注意的是,事件处理函数在绑定时不要包含括号。如果加上括号,表示在组件渲染时立即调用该函数。...传递参数有时我们需要将额外的参数传递给事件处理函数。在React中,我们可以使用箭头函数或.bind()方法来实现。...我们使用箭头函数和.bind()方法来传递不同的id值给事件处理函数。

    70830

    React中的合成事件

    React中的合成事件 React自己实现了一套高效的事件注册、存储、分发和重用逻辑,在DOM事件体系基础上做了很大改进,减少了内存消耗,简化了事件逻辑,并最大程度地解决了IE等浏览器的不兼容问题。...描述 React的合成事件SyntheticEvent实际上就是React自己在内部实现的一套事件处理机制,它是浏览器的原生事件的跨浏览器包装器,除兼容所有浏览器外,它还拥有和浏览器原生事件相同的接口,...包括stopPropagation()和preventDefault(),合成事件与浏览器的原生事件不同,也不会直接映射到原生事件,也就是说通常不要使用addEventListener为已创建的DOM元素添加监听器...ownerDocument可返回某元素的根元素,在HTML中HTML文档本身是元素的根元素,所以可以说明其实大部分的事件都是注册在document上面的,之后便是调用listenTo方法实际注册。...使用e. nativeEvent,因为它是持久引用的。 事件分发 事件分发就是遍历找到当前元素及父元素所有绑定的事件,将所有的事件放到event.

    2.3K10
    领券