Home Web Front-end JS Tutorial What are the differences in the response mechanisms between bubbling and non-bubbly events?

What are the differences in the response mechanisms between bubbling and non-bubbly events?

Feb 19, 2024 pm 11:49 PM
the difference click event bubbling event non-bubble event

What are the differences in the response mechanisms between bubbling and non-bubbly events?

What is the difference between bubbling events and non-bubbling events, specific code examples are needed

Events play an important role in programming, it can be the user's Interaction behavior (such as click, drag, etc.), or internal behavior of the browser or web page (such as loading completion, window size change, etc.). According to different event propagation methods, events can be divided into bubbling events and non-bubble events.

Bubbling Events
Bubbling events refer to events that will start from the event target and propagate to the upper elements step by step until they reach the document root node. During the propagation process, the event handler of the parent element will be triggered first, then the event handler of the grandparent element, and so on, until the event handler on the root node.

The following is a sample code for a bubbling event:

HTML code:

<div id="outer">
  <div id="inner">
    <button id="button">点击</button>
  </div>
</div>
Copy after login
Copy after login

JavaScript code:

var outer = document.getElementById('outer');
var inner = document.getElementById('inner');
var button = document.getElementById('button');

button.addEventListener('click', function(event) {
  console.log('按钮被点击');
});

inner.addEventListener('click', function(event) {
  console.log('内部div被点击');
});

outer.addEventListener('click', function(event) {
  console.log('外部div被点击');
});
Copy after login

When the button is clicked, the console will Output the following content:

按钮被点击
内部div被点击
外部div被点击
Copy after login

It can be seen from the output that the bubbling event first triggers the click event handler of the button, then the click event handler of the inner div, and finally the click event handler of the outer div. .

Non-bubbling Events
Non-bubbling events refer to events that will only be triggered on the event target and will not propagate upward. In other words, only the event handler of the clicked element will be executed.

The following is a sample code for a non-bubbling event:

HTML code:

<div id="outer">
  <div id="inner">
    <button id="button">点击</button>
  </div>
</div>
Copy after login
Copy after login

JavaScript code:

var outer = document.getElementById('outer');
var inner = document.getElementById('inner');
var button = document.getElementById('button');

button.addEventListener('click', function(event) {
  console.log('按钮被点击');
});

inner.addEventListener('click', function(event) {
  console.log('内部div被点击');
});

outer.addEventListener('click', function(event) {
  console.log('外部div被点击');
}, true);
Copy after login

When the button is clicked, the console Only the following content will be output:

按钮被点击
Copy after login

As can be seen from the output results, the non-bubbling event only triggered the click event handler of the button.

To sum up, the main difference between bubbling events and non-bubbly events is the way the event is propagated. Bubbling events will propagate from the event target to upper elements, while non-bubbling events will only be triggered on the event target. Understanding the difference between these two events is very important for handling event propagation and optimizing the interactive effect of the page.

The above is the detailed content of What are the differences in the response mechanisms between bubbling and non-bubbly events?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

The difference between multithreading and asynchronous c# The difference between multithreading and asynchronous c# Apr 03, 2025 pm 02:57 PM

The difference between multithreading and asynchronous is that multithreading executes multiple threads at the same time, while asynchronously performs operations without blocking the current thread. Multithreading is used for compute-intensive tasks, while asynchronously is used for user interaction. The advantage of multi-threading is to improve computing performance, while the advantage of asynchronous is to not block UI threads. Choosing multithreading or asynchronous depends on the nature of the task: Computation-intensive tasks use multithreading, tasks that interact with external resources and need to keep UI responsiveness use asynchronous.

What is the function of C language sum? What is the function of C language sum? Apr 03, 2025 pm 02:21 PM

There is no built-in sum function in C language, so it needs to be written by yourself. Sum can be achieved by traversing the array and accumulating elements: Loop version: Sum is calculated using for loop and array length. Pointer version: Use pointers to point to array elements, and efficient summing is achieved through self-increment pointers. Dynamically allocate array version: Dynamically allocate arrays and manage memory yourself, ensuring that allocated memory is freed to prevent memory leaks.

The difference between char and wchar_t in C language The difference between char and wchar_t in C language Apr 03, 2025 pm 03:09 PM

In C language, the main difference between char and wchar_t is character encoding: char uses ASCII or extends ASCII, wchar_t uses Unicode; char takes up 1-2 bytes, wchar_t takes up 2-4 bytes; char is suitable for English text, wchar_t is suitable for multilingual text; char is widely supported, wchar_t depends on whether the compiler and operating system support Unicode; char is limited in character range, wchar_t has a larger character range, and special functions are used for arithmetic operations.

What are the differences and connections between c and c#? What are the differences and connections between c and c#? Apr 03, 2025 pm 10:36 PM

Although C and C# have similarities, they are completely different: C is a process-oriented, manual memory management, and platform-dependent language used for system programming; C# is an object-oriented, garbage collection, and platform-independent language used for desktop, web application and game development.

c What are the differences between the three implementation methods of multithreading c What are the differences between the three implementation methods of multithreading Apr 03, 2025 pm 03:03 PM

Multithreading is an important technology in computer programming and is used to improve program execution efficiency. In the C language, there are many ways to implement multithreading, including thread libraries, POSIX threads, and Windows API.

How to use XPath to search from a specified DOM node in JavaScript? How to use XPath to search from a specified DOM node in JavaScript? Apr 04, 2025 pm 11:15 PM

Detailed explanation of XPath search method under DOM nodes In JavaScript, we often need to find specific nodes from the DOM tree based on XPath expressions. If you need to...

Concept of c language function Concept of c language function Apr 03, 2025 pm 10:09 PM

C language functions are reusable code blocks. They receive input, perform operations, and return results, which modularly improves reusability and reduces complexity. The internal mechanism of the function includes parameter passing, function execution, and return values. The entire process involves optimization such as function inline. A good function is written following the principle of single responsibility, small number of parameters, naming specifications, and error handling. Pointers combined with functions can achieve more powerful functions, such as modifying external variable values. Function pointers pass functions as parameters or store addresses, and are used to implement dynamic calls to functions. Understanding function features and techniques is the key to writing efficient, maintainable, and easy to understand C programs.

In Hongmeng application development, how to capture user interaction behavior? In Hongmeng application development, how to capture user interaction behavior? Apr 04, 2025 pm 05:18 PM

In Hongmeng application development, how to effectively capture user interaction behavior is a common concern for developers. Especially how to open it through a traditional...

See all articles