Home > Web Front-end > JS Tutorial > JavaScript variable scope analysis (detailed explanation)

JavaScript variable scope analysis (detailed explanation)

青灯夜游
Release: 2018-09-13 17:50:42
Original
1162 people have browsed it

This chapter brings you JavaScript variable scope analysis (detailed explanation), so that you can learn some little knowledge about JavaScript scope. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you.

What is JavaScript scope?

In JavaScript, scope is a collection of accessible variables, objects, and functions.

The scope can be modified within the function.

JavaScript local scope

Variables are declared within the function and are local variables (local scope)

local Variables: can only be accessed inside the function.

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
    <button onclick="myFunction(1,2)">试一试</button>
    <p id="demo"></p>
</body>
<script type="text/javascript">
    function name() {
        //在此处声明一个变量
        var a = 10;
        //函数内可以调用 a
    }
    //此处(函数外)不能调用变量 a  
    //因为局部变量只作用于函数内,所以不同的函数可以使用相同名称的变量名  
    //局部变量在函数开始执行时创建,函数执行完毕后,变量会自动销毁
</script>
</html>
Copy after login

JavaScript global variables

Variables defined outside the function are global variables.

Global variables have global scope and can be used by all scripts and functions in the web page.

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
    <button onclick="myFunction(1,2)">试一试</button>
    <p id="demo"></p>
</body>
<script type="text/javascript">
    /* 在此处声明一个全局变量 */
    var a = 10;
    function name() {
        //函数内可以调用 a
    }
    //此处也能调用变量 a
</script>
</html>
Copy after login

If the variable is not declared within the function (not declared using the var keyword), the change amount is a global variable.

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
    <button onclick="myFunction(1,2)">试一试</button>
    <p id="demo"></p>
</body>
<script type="text/javascript">
    
    function name() {
        /* 在此处声明一个变量 */
          a = 10;
     /* a没有使用var关键字声明,则默认为全局变量 */

    }
    
</script>
</html>
Copy after login

JavaScript variable life cycle

The life cycle of a variable is initialized at the time of its declaration. Local variables are destroyed after the function completes execution. Global variables are destroyed after the page is closed.

Function parameters

Function parameters only work within the function and are local variables.

Global variables in HTML

In HTML, global variables are window objects, and all data variables belong to the window object.

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
    <button onclick="myFunction(1,2)">试一试</button>
    <p id="demo"></p>
</body>
<script type="text/javascript">
    function name() {
         a = 10;
    }
    //此处可使用window.a调用变量 a
</script>
</html>
Copy after login

Global variables or functions can override the variables or functions of the window object. Local variables include window objects and can override global variables and functions.

The let keyword and the const keyword are provided in es6

The declaration method of let is the same as that of var. Using let instead of var to declare variables can limit the current variable to the code block. .

Using const to declare a constant, its value cannot be changed once it is set.

The above is the detailed content of JavaScript variable scope analysis (detailed explanation). For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
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
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template