Preface: Before learning about block-level scope, we need to have an understanding of scope. The so-called scope is the range within which a member in the code works. 1. What is block scope? The so-called block-level scope means that the variable can only be used in the code block or sub-code block where it is declared. There is no block-level scope in versions prior to /* * Block-level scope can only use the let keyword* The let keyword can not only declare block-level scope, but also can be used in global scope and function scope*/ // Global scope let a = 100; // Global variables (function () { // function scope let b = 200; // local variable })() if (true) { // block scope let c = 300; // local variable } console.log(a); // 100 console.log(b); // throws an exception console.log(c); // throws an exception 2. Why do we need block scope? Local variables may overwrite global variables var v = 100; (function(){ console.log(v); // undefined var v = 200; }) The variable used for counting in the loop body is leaked as a global variable // Define a loop body for (var v = 0; v < 10; v++) { console.log("This is a for loop"); // This is a for loop * 10 } console.log(v); // 10 If the variable is not released manually after the loop is completed, its life cycle will survive with the script and occupy memory. 3. With function declaration Case 1: if (true) { function f() {} } Case 2: try { function f() {} } catch(e) { // ... } The above two function declarations are illegal according to { function fun() { console.log('this is fun'); } } fun(); // this is fun // The above is equivalent to the following function { var fn = function () { console.log('this is fn'); } } fn(); // this is fn // If you use the let keyword, you cannot access it outside the block scope { let f = function () { console.log('this is f'); } } f(); // Throws an exception description of ReferenceError: f is not defined This is the end of this article about the new block-level scope feature of You may also be interested in:
|
<<: Introduction to commonly used fonts on the Web (fonts supported by iOS and Android browsers)
>>: Summary of @ usage in CSS (with examples and explanations)
Operating system: windowns10_x64 Python version: ...
<br />When thoughts were divided into East a...
WeChat applet uniapp realizes the left swipe to d...
Table of contents 1. Use the uuid function to gen...
background Basic Concepts CSS filter property app...
This post focuses on a super secret Flutter proje...
Query Rewrite Plugin As of MySQL 5.7.6, MySQL Ser...
This article example shares the specific code of ...
This article uses examples to illustrate the prin...
For historical reasons, MySQL replication is base...
This article shares with you how to use Vue to im...
Table of contents 502 bad gateway error formation...
When the scroll bar is pulled down, the floating ...
Learning objectives: The two functions parseInt()...