Javascript tutorial use strict strict mode detailed explanation
Strict mode: The JavaScript standard defined by the ECMA-262 specification has stronger restrictions on javascript. This article mainly introduces the detailed explanation of JavaScript strict mode use strict. Friends who need it can refer to
Strict mode: The JavaScript standard defined by the ECMA-262 specification has stronger restrictions on javascript.
(Non-strict mode is called "sloppy mode/sparse mode/lazy mode".)
1. Use of strict mode
Strict mode can be implemented at the script or function level. (i.e. global and local modes)
1. Global
Add "use strict" at the front of the js file
2. Local
in the function Add "use strict" internally, as follows
function fn() { "use strict"; //some code }
2. Comparison between strict mode and non-strict mode
1. In strict mode, variables cannot be deleted (delete is an unqualified identifier)). In non-strict mode, deletion failure will return false
"use strict"; var x; delete x;//报错Delete of an unqualified identifier in strict mode.(不合格的标识符)
2. In strict mode, if the function parameter has the same name, an error will be thrown; non-strict mode will not
In strict mode
function fn(a,a){ "use strict"; result=a+a; console.log(result); } fn(2,4);//Duplicate parameter name not allowed in this context(重复的参数名称在此上下文中不允许)
In non-strict mode
function fn1(a,a){ "use strict"; result=a+a; console.log(result); } fn1(2,4);//结果为8
3. Strict mode does not allow octal integers Direct quantity (below). No error will be reported in non-strict mode.
"use strict" var x=089; console.log(x);//报错:Decimals with leading zeros are not allowed in strict mode.
4. In strict mode, the arguments object is a static copy of the actual parameter list passed into the function (that is, changes in parameters are no longer tracked); in non-strict mode, The elements in the arguments object and the corresponding actual parameters are references to the same value.
In strict mode
fn(5); function fn(a){ "use strict"; a = 42; // return a==arguments[0];//返回false console.log(a);//结果为42 console.log(arguments[0]);//结果为5,严格模式下arguments[0]表示这个调用方法的第一个参数 (不再追踪 参数的变化,在函数内部,参数a被重新赋值为42,但arguments[0]仍然为5.) }
In non-strict mode
fn(5); function fn(a){ a = 42; // return a==arguments[0];//返回true console.log(a);//结果为42 console.log(arguments[0]);//结果为42(追踪参数变化) }
5. In strict mode eval and arguments are used as keywords, they cannot be assigned and used as variable declaration
"use strict"; var eval=3;//报错:Unexpected eval or arguments in strict mode var argument=6;//同样报错
6. Strict mode will limit the ability to detect the call stack, access arguments.callee, arguments.callee.caller will throw an exception
In strict mode:
"use strict"; function fn(n){ if(n==0){ return 1; }else{ return n*arguments.callee(n-1); } } console.log(fn(5));//报错
In non-strict mode:
function fn(n){//阶乘 if(n==0){ return 1; }else{ return n*arguments.callee(n-1); } } console.log(fn(5));//正常120
caller: When a function calls another function, the called function will automatically generate a caller attribute pointing to the function object that called it. If the function is not currently called, or is not called by another function,
caller is null. As follows:
In strict mode:
"use strict" function fn1() { var n1= fn1.caller; console.log(n1); } function fn2() { fn1(); } fn2();//报错
In non-strict mode:
function fn1() { var n1= fn1.caller;//此例中caller指向调用它的函数(fn2) console.log(n1); } function fn2() { fn1(); } fn2();// 结果打印出:function fn2(){ fn1( ) };
7 .Strict mode variables must be declared first and assigned directly to the variable. Global variables will not be created implicitly and with cannot be used.
In strict mode
"use strict"; with(obj){ x; }//报错:Strict mode code may not include a with statement
Explanation: When running a script, it is compiled first and then executed. Obviously at compile time, it cannot be determined at compile time which object the variables in the with statement block belong to. [Is the variable in the with statement block an attribute
of (cl) or a variable in the upper-level variable scope chain. ]. It can only be determined at execution time that (c1) is an instance of Clothes. This conflicts with strict mode, which checks whether variables are defined at compile time, so strict mode does not use the with statement.
Extension: Use of with statement (used to reference existing attributes in a specific object, but cannot be used to add attributes to the object.)
with(object instance) { //代码块 } eg:function Clothes(){ this.color="red"; this.size="m"; this.price="cheap"; } var c1=new Clothes(); with(c1){ var str="颜色:"+color+",尺寸:"+size+",价格:"+price; document.write(str); }//结果(颜色:red,尺寸:m,价格:cheap)
In strict mode, null undefined passed in to call apply remains as is and is not converted to window
The above is the detailed content of Javascript tutorial use strict strict mode detailed explanation. 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

AI Hentai Generator
Generate AI Hentai for free.

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.

Essential tools for stock analysis: Learn the steps to draw candle charts in PHP and JS. Specific code examples are required. With the rapid development of the Internet and technology, stock trading has become one of the important ways for many investors. Stock analysis is an important part of investor decision-making, and candle charts are widely used in technical analysis. Learning how to draw candle charts using PHP and JS will provide investors with more intuitive information to help them make better decisions. A candlestick chart is a technical chart that displays stock prices in the form of candlesticks. It shows the stock price

Face detection and recognition technology is already a relatively mature and widely used technology. Currently, the most widely used Internet application language is JS. Implementing face detection and recognition on the Web front-end has advantages and disadvantages compared to back-end face recognition. Advantages include reducing network interaction and real-time recognition, which greatly shortens user waiting time and improves user experience; disadvantages include: being limited by model size, the accuracy is also limited. How to use js to implement face detection on the web? In order to implement face recognition on the Web, you need to be familiar with related programming languages and technologies, such as JavaScript, HTML, CSS, WebRTC, etc. At the same time, you also need to master relevant computer vision and artificial intelligence technologies. It is worth noting that due to the design of the Web side

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

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.

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

With the rapid development of Internet finance, stock investment has become the choice of more and more people. In stock trading, candle charts are a commonly used technical analysis method. It can show the changing trend of stock prices and help investors make more accurate decisions. This article will introduce the development skills of PHP and JS, lead readers to understand how to draw stock candle charts, and provide specific code examples. 1. Understanding Stock Candle Charts Before introducing how to draw stock candle charts, we first need to understand what a candle chart is. Candlestick charts were developed by the Japanese

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
