- Why was strict mode introduced?
- What is strict mode in JS?
- How to enable strict mode?
- What are the changes in strict mode?
The spec for ECMAScript 2020 says:
The strict variant of the language excludes some specific syntactic and semantic features of the regular ECMAScript language and modifies the detailed semantics of some features. The strict variant also specifies additional error conditions that must be reported by throwing error exceptions in situations that are not specified as errors by the non-strict form of the language.
Why was strict mode introduced?
Strict mode was introduced in ECMAScript 5 (ES5).
When JS was released, there were a few mistakes or imperfect decisions which got stuck in the language forever. To fix these decisions would mean that all the programs written before the fix would break. To make sure that didn't happen and to make the fixes too, ES5 contributors came up with a workaround where the fixes would be processed only if strict mode is enabled.
What is strict mode in JS?
Strict mode is an opt-in feature in JS which needs to be explicitly enabled. Once enabled the processing of code changes in a couple of ways:
- Some JS silent errors are changed to throw error exceptions.
- Prohibits use of certain syntax.
- Allows JS engines to perform a few optimisations to evaluate JS code.
How to enable strict mode?
To enable strict mode "use strict;"
must be placed at the top of the script. It can only be preceded by comments.
When I say it must be placed at the top of the script, it means at the top of the execution context.
- It can be placed at the top of a
.js
file and the whole file will be processed in strict mode.
// comments...
"use strict";
// code here will be processed in strict mode
...
- It can also be placed at the beginning of a function and only the code inside that function would be processed in strict mode. This comes in handy when migration of legacy codebase to strict mode can be made in small individual function-by-function pieces.
// code here will be processed in non-strict mode
var a = "non-strict code";
function strictModeCode(){
// comments
"use strict";
// code here will be processed in non-strict mode
var b = "strict mode"
}
...
- JS Modules which was introduced in ES6 has strict mode enabled by default in exported modules.
function moduleFunction() {
// because this is a module, code here is processed in
// strict mode by default
}
export default moduleFunction;
...
- All the code inside classes are processed in strict mode by default.
class stictClass {
// because this is inside a class, code here is processed
// in strict mode by default
constructor() { ... }
}
Most of the times the code that we write is transpiled before it is run on production. Most Transpilers enable strict mode by default.
What are the changes in strict mode?
These are the restriction and exceptions in strict mode in ECMAScript 2020:
implements
,interface
,let
,package
,private
,protected
,public
,static
, andyield
are reserved keywords.Assigning values to undeclared variables will throw
ReferenceError
and assigning values to non-writable properties will throwTypeError
.
a = "undeclared variable"; // ReferenceError
var NaN = "Read Only property" // TypeError
- Using
delete
operator on a variable, function argument, or function name will throw aSyntaxError
. Whendelete
is used on non-configurable propertiesTypeError
is thrown.
var a = "cool varaible";
delete a; // SyntaxError
delete Object.prototype; // TypeError
- Multiple parameters with same name cannot be used in a function, generator, or asyncFunction.
function duplicateParamNames(a, a) { ... } // SyntaxError
-
eval
orarguments
cannot be used as parameter names forcatch()
statements.
function InvalidParamNames(eval, arguments) { ... } // SyntaxError
-
with()
statements are not allowed.
with (expression) { ... } // SyntaxError
If the value of
this
isundefined
ornull
it is not converted to the global object.this
is not coerced to an object. Boxing does not happen on the value ofthis
.eval
orarguments
cannot be used as a variable names.
var eval = "variable name is eval" // SyntaxError
var arguments = "variable name is arguments" // SyntaxError
- Octal numeric literals and octal escape characters are not allowed.
var variableWithOctalLiteralAsValue = 010 // SyntaxError
var variableWithOctalEscapeCharacter = "\010"; // SyntaxError
- Functions processed in strict mode define non-configurable properties
callee
andcaller
to it'sarguments
object. These properties are not accessible.
function CalleeAccessor() {
return arguments.callee; // TypeError
}
function CallerAccessor() {
return arguments.caller; // TypeError
}
Variables created inside
eval
code will be created in a separate execution context and theeval
code cannot instantiate variables or functions in the execution context of where eval was called.Inside a function if the value of an argument is changed it does not automatically change the associated property in
arguments
object.
function changeArgValue(a) {
a = 50;
return [a,arguments[0]];
}
var values = changeArgValue(49);
console.log(values[0]); // 50
console.log(values[1]); // 49
- The properties
caller
andarguments
inside a function cannot be changed or read.
function restrictedPropertiesAccessor(a) {
changeArgValue.arguments; // TypeError
changeArgValue.caller; // TypeError
}
I have tried to cover all the changes in strict mode. If I have missed something please let me know. :)
Fin.
Next post is going to be about Errors in javascript.
I have taken up a challenge to post good-to-know stuff in JS for thirty days. Please follow me @zlfnhmd for updates and to show some love❤️❤️❤️
Top comments (0)