Home Web Front-end JS Tutorial Why you need to avoid using global variables in web development

Why you need to avoid using global variables in web development

Jun 04, 2018 am 10:13 AM
web Why use

This time I will bring you why you need to avoid using global variables in web development, and what are the precautions to avoid using global variables in web development. The following is a practical case, let's take a look.

The main problems caused by global variables are: as the amount of code increases, too many global variables will make the code difficult to maintain and prone to bugs. There is no big problem with one or two global variables. It is almost impossible to achieve zero global variables (unless your JS code is not related to any other JS code and just does some things of its own. This situation is very rare, which does not mean that there is no global variable. ).

If you are writing ES6 code, you will find that it is difficult to create a global variable. Unless you explicitly write window.globalVar = 'something', the ES6 module mechanism automatically sets the scope for you. Splitting makes the code you write more maintainable and secure (old JSers have to lament that modern front-end developers are so happy).

If it is code before ES6, you have to pay attention. For example, variables you declare without using var in a function will be directly mounted into global variables (this should be basic knowledge of JS), so modularization is generally implemented through IIFE, and only one global variable is exposed to the outside world (of course, you You can also use third-party module management tools such as RequireJS or YUI module loader to achieve modularization).

window.global = (function () {  var exportVar = {}; // ES5没有let和const,故用var
  // add method and variable to exportVar
  return exportVar;
})();
Copy after login

I believe you have mastered the method after reading the case in this article. For more exciting information, please pay attention to other related articles on the php Chinese website!

Recommended reading:

Use JS to implement encryption and decryption operations

JS array operation and parsing method summary

The above is the detailed content of Why you need to avoid using global variables in web development. 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

Repo: How To Revive Teammates
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months 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)

WordPress site file access is restricted: Why is my .txt file not accessible through domain name? WordPress site file access is restricted: Why is my .txt file not accessible through domain name? Apr 01, 2025 pm 03:00 PM

Wordpress site file access is restricted: troubleshooting the reason why .txt file cannot be accessed recently. Some users encountered a problem when configuring the mini program business domain name: �...

Why does an error occur when installing an extension using PECL in a Docker environment? How to solve it? Why does an error occur when installing an extension using PECL in a Docker environment? How to solve it? Apr 01, 2025 pm 03:06 PM

Causes and solutions for errors when using PECL to install extensions in Docker environment When using Docker environment, we often encounter some headaches...

Django time range query: Why does the __range parameter not contain an end date? Django time range query: Why does the __range parameter not contain an end date? Apr 01, 2025 pm 04:06 PM

Question about Django time range query: Why is the end date not included? When using Django for database queries, we often need to use the time...

Failed to obtain Taobao order data: Why do you still jump to the login page with cookies and URL parameters? Failed to obtain Taobao order data: Why do you still jump to the login page with cookies and URL parameters? Apr 02, 2025 am 06:54 AM

Difficulty in obtaining Taobao order data: Bypassing the challenge of login page Many friends will encounter a difficult problem when trying to obtain information about purchased products on Taobao:...

Jiutian Computing Power Platform Task: Will the computing task continue to run after the local computer is shut down? Jiutian Computing Power Platform Task: Will the computing task continue to run after the local computer is shut down? Apr 01, 2025 pm 11:57 PM

Discussion on the task status after the local computer of Jiutian Computing Power Platform is closed. Many users will encounter a question when using Jiutian Computing Power Platform for artificial intelligence training...

Why can't my code get the data returned by the API? How to solve this problem? Why can't my code get the data returned by the API? How to solve this problem? Apr 01, 2025 pm 08:09 PM

Why can't my code get the data returned by the API? In programming, we often encounter the problem of returning null values ​​when API calls, which is not only confusing...

Why does garbled code appear in Chinese when running Python CGI scripts on an Apache server? Why does garbled code appear in Chinese when running Python CGI scripts on an Apache server? Apr 01, 2025 pm 07:15 PM

Python CGI script on Apache server shows the problem in using Apache server to execute Python CGI...

Why does an error 'Property does not exist' when calling a property in a Python class? Why does an error 'Property does not exist' when calling a property in a Python class? Apr 01, 2025 pm 07:18 PM

Problem description is using Python...

See all articles