This article will take you to understand the global objects in node, and introduce the difference between nodejs global objects and global objects in the browser. I hope it will be helpful to everyone!
In Node.js, a .js file is a complete scope (module, module). Therefore, variables declared with var are only valid in the current .js file, not globally. The global global object is independent of all .js (module, module).
The top-level global object in the browser is window, and variables declared by var are bound to the window object by default
Concept: Objects that can be accessed anywhere in the program are called global objects. Properties of objects are called global variables.
Here we summarize what are our commonly used global variables in nodejs
2.1 Buffer class
Buffer, we can also call it a "buffer", its function is to open up a piece of memory in the memory Area used to store binary data.
2.2 __dirname
__dirname, returns the folder where the current module file is located after parsing The absolute path to (directory).
Please remember that __dirname is not a true global variable.
2.3 __filename
##__filename, returns the current module file The parsed absolute path.
Please remember that __filename is not really a global variable.2.4 <span style="font-size: 18px;"></span>module<span style="font-size: 18px;"></span>
##Please remember that module is not a true global variable.
2.5 <span style="font-size: 18px;"></span>require()<span style="font-size: 18px;"></span>
Please remember that require() is not really global variables.
2.6 <span style="font-size: 18px;"></span>exports<span style="font-size: 18px;"></span>
Remember, exports are not really global variables.
2.7 <span style="font-size: 18px;"></span>setImmediate<span style="font-size: 18px;"></span> and
<span style="font-size: 18px;"></span>clearImmediate<span style="font-size: 18px;"></span>
2.8 <span style="font-size: 18px;"></span>setTimeout<span style="font-size: 18px;"></span> and
<span style="font-size: 18px;"></span>clearTimeout<span style="font-size: 18px;"></span>
2.9 <span style="font-size: 18px;"></span>setInterval<span style="font-size: 18px;"></span> and
<span style="font-size: 18px;"></span>clearInterval <span style="font-size: 18px;"></span>
2.10 <span style="font-size: 18px;"></span>console<span style="font-size: 18px;"></span>
is used to print to standard output and standard error
process<span style="font-size: 18px;"></span>
process
URL<span style="font-size: 18px;"></span>
URL
events<span style="font-size: 18px;"></span>##events module is Node's answer to "publish/ Implementation of the "subscribe" model (publish/subscribe). One object passes messages to another object through this module. This module provides a constructor through the EventEmitter property.
The JS language is increasingly used in a variety of environments. In addition to the most common browsers, it can run on servers, smartphones, and even robot hardware. Each environment has its own object model and provides different syntax to access global objects. For example, in a web browser, global objects can be accessed through window, self, or frames. However, in Node.js, these properties do not exist and global must be used instead.
globalThis aims to consolidate the increasingly fragmented methods of accessing global objects by defining a standard global property. The proposal was incorporated into the ES2020 standard. All popular browsers, including Chrome 71, Firefox 65 and Safari 12.1, already support this feature. You can also use it in Node.js 12.
For more node-related knowledge, please visit: nodejs tutorial! !
The above is the detailed content of Understand the global object in nodejs and see the difference between it and the global object in the browser. For more information, please follow other related articles on the PHP Chinese website!