In-depth understanding of JavaScript event mechanism
This article introduces an in-depth understanding of the event mechanism of JavaScript and has a certain reference value. Now I share it with you. Friends in need can refer to it
What is an event
First of all, let’s use a person as an analogy. People can sleep, but only when people feel sleepy will they go to sleep.
In program terms, the object human has a sleep method. This method will only be executed when the event mental fatigue is triggered:
function sleep(){ do sleep } man.ontired=function(){ sleep(); }
Of course, some Because a lot of work has not been completed, people still have to work overtime even if they are tired at 12 o'clock in the night. At this time, people may execute a method to continue working after triggering MENTAL FATIGUE (such as my QAQ. . .
man.ontired=function(){ work() }
So events are widely present around us, that is, a trigger point, just like a switch, the light turns on when you press it. The light goes out. This is an event.
- ##Put the event on the web. To be precise, it should be in the browser. What is the event? The answer is of course the user's response to all actions performed by the browser, such as the simplest clicks, keyboard presses, mouse movements, closing web pages, loading web pages, etc., as long as the browser can. All those that respond to user behavior are web events. For example, if a user smashes the computer angrily, the browser cannot monitor or respond, so it is not considered a web event.
- ##So, an event is a response of the browser to user behavior
js is event-driven
And it is Programmers and users can relate to the existence of these events. Programmers don't know what users do on the web page, but programmers know how to deal with it after users do those actions. You can imagine our front-end programmers. They are all landmines. The page is covered with "event mines" of all sizes. As long as the user does not step on them, the code we wrote will lie in the js file and never trigger. But once the user clicks and drags, the code will not be triggered. If we press a button and step on an "event mine", the code we write will start executing with a "boom" like a mine, for example:
.document.body.onclick=function(){ alert('boom') }
如果用户只是打开了网页,根本没有点击页面,那么这个"boom"永远不会弹出来。
因为js是事件驱动的。
事件驱动是什么?
上面那几个例子已经很好说明了什么是事件驱动。事件驱动就是,事件没发生,代码不执行,事件是触发代码执行的直接原因。
一般来讲,可能你有遇到,在一个点击事件里面写了一个小小或者大大的逻辑错误,js页面加载的时候并不会给你报错,它只是匆匆看了一眼
onclick
里面的内容,但不会去执行它,自然不会去发现里面的逻辑错误,除非你里面写了一个语法错误,js看了一眼发现,卧槽这里面的语句不通顺读不通啊,它才会提示错误。只有你点击事件触发的时候,js执行了下代码,然后发现里面的逻辑狗屁不通,然后才会报错。通常我们都会写个window.onload,页面加载完成触发的事件,把要执行的代码放里面,这样资源加载好了js好操作。但是,页面还存在一个隐性的事件,就是read事件,js引擎阅读代码事件。如果读到了
function 函数名(){...}
活着var 函数名=function(){...}
这样的结构,它会匆匆扫一眼,不执行里面的代码,然后继续读下去,其他的语句一旦遇到了,js就会去执行它。比如var 变量名
或着函数名()
这样。这个是read事件,其他事件也类似,只有当前浏览器对用户行为的响应时,js才会执行里面的代码。
其他语言的事件驱动
说到事件驱动,还有一个语言也是事件驱动的,那就是php(我所知道的。。。)。
php的事件驱动在于,它同样为服务器划分了事件,最简单的,一个请求进来,这是一个事件;服务器做出一个响应,这也是一个事件。然后后台服务器围绕这几个事件,一旦触发哪个就执行相关代码。
-
js的后台版node也是一样的
Related recommendations:
Event flow mechanism of JS events
The above is the detailed content of In-depth understanding of JavaScript event mechanism. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

How to use WebSocket and JavaScript to implement an online speech recognition system Introduction: With the continuous development of technology, speech recognition technology has become an important part of the field of artificial intelligence. The online speech recognition system based on WebSocket and JavaScript has the characteristics of low latency, real-time and cross-platform, and has become a widely used solution. This article will introduce how to use WebSocket and JavaScript to implement an online speech recognition system.

WebSocket and JavaScript: Key technologies for realizing real-time monitoring systems Introduction: With the rapid development of Internet technology, real-time monitoring systems have been widely used in various fields. One of the key technologies to achieve real-time monitoring is the combination of WebSocket and JavaScript. This article will introduce the application of WebSocket and JavaScript in real-time monitoring systems, give code examples, and explain their implementation principles in detail. 1. WebSocket technology

Introduction to how to use JavaScript and WebSocket to implement a real-time online ordering system: With the popularity of the Internet and the advancement of technology, more and more restaurants have begun to provide online ordering services. In order to implement a real-time online ordering system, we can use JavaScript and WebSocket technology. WebSocket is a full-duplex communication protocol based on the TCP protocol, which can realize real-time two-way communication between the client and the server. In the real-time online ordering system, when the user selects dishes and places an order

How to use WebSocket and JavaScript to implement an online reservation system. In today's digital era, more and more businesses and services need to provide online reservation functions. It is crucial to implement an efficient and real-time online reservation system. This article will introduce how to use WebSocket and JavaScript to implement an online reservation system, and provide specific code examples. 1. What is WebSocket? WebSocket is a full-duplex method on a single TCP connection.

JavaScript and WebSocket: Building an efficient real-time weather forecast system Introduction: Today, the accuracy of weather forecasts is of great significance to daily life and decision-making. As technology develops, we can provide more accurate and reliable weather forecasts by obtaining weather data in real time. In this article, we will learn how to use JavaScript and WebSocket technology to build an efficient real-time weather forecast system. This article will demonstrate the implementation process through specific code examples. We

JavaScript tutorial: How to get HTTP status code, specific code examples are required. Preface: In web development, data interaction with the server is often involved. When communicating with the server, we often need to obtain the returned HTTP status code to determine whether the operation is successful, and perform corresponding processing based on different status codes. This article will teach you how to use JavaScript to obtain HTTP status codes and provide some practical code examples. Using XMLHttpRequest

Usage: In JavaScript, the insertBefore() method is used to insert a new node in the DOM tree. This method requires two parameters: the new node to be inserted and the reference node (that is, the node where the new node will be inserted).

JavaScript is a programming language widely used in web development, while WebSocket is a network protocol used for real-time communication. Combining the powerful functions of the two, we can create an efficient real-time image processing system. This article will introduce how to implement this system using JavaScript and WebSocket, and provide specific code examples. First, we need to clarify the requirements and goals of the real-time image processing system. Suppose we have a camera device that can collect real-time image data
