JavaScript has a feature called Scope. Though the concept of scope is not that easy to understand for many new developers . In this article, you’ll learn what the term ‘Scope’ means and how it is controlled in Javascript. Also, you’ll learn how to manage it all through your program so as to avoid unexpected results.
Scope is the accessibility of variables, functions, and objects in some particular part of your code during runtime. In other words, scope determines the visibility of variables and other resources in areas of your code.
Just as several languages maintain scopes for objects, they also have their methods of doing so.
Javascript scopes are of two major types which are;
Other types include;
This scope which is the default defines all variables as universal such that every part of the program can access them.
Let’s take an example;
//script.js
var name = 'soshace';
function assignName(parameter) {
name = parameter;
}
assignName('javascript');
console.log(name);
// the expected result
// javascript
Variable ‘name’ can be accessed anywhere in this file and can also be altered because it is available in the global space.
We also have a function, assignName
. After executing this program, ‘javascript’ is logged to the console.
We note that this function was able to alter the variable because it is in the global scope.
This can be related to our scenario above. The global scope here refers to the general privileges which are given to everyone.
Here, if the value of name
changes after including so many functions in this program, it would be hard to tell which particular function altered it.
This brings us to Local Scope.
This scope is created with functions. They house variables thereby making it impossible for outside parts of the function to access them.
For example, let’s say we have a function in our program above which has its own variables;
// script.js
//new line
"use strict";
var name = 'soshace';
// new function start
function house() {
var topic = "scoping";
}
// new function end
function assignName(parameter) {
name = parameter;
topic = parameter;
}
house(); // executing the house function
assignName('javascript');
topic = 'local';
console.log(name);
console.log(topic);
// the expected result
// javascript
// topic is not defined
Note
"use strict";
– This, at the top of the program, is a literal expression that indicates that all codes in this program should be executed in strict mode. With this activated, you can’t use any variable that hasn’t been defined. If this wasn’t activated, thetopic
variable can still be used without an earlier definition.
- topic is not defined – Even though the
house
function was executed before theassignName
function, thetopic
variable remains inaccessible because it has been locally scoped to thehouse
function. Hence, neither the global environment nor other functions can have access tohouse
‘s variables.
This scope is defined by curly braces – { and }. These braces can be found in functions
, if
statements, switch
statements, loop
statements and so on.
Generally, these braces make up a block scope.
The variables defined and declared here are only accessible within the scope.
NOTE: Local scope is defined by functions while block scope is defined by curly braces.
The difference between global, local and block scope can be explained with the ‘var’, ‘let’ and ‘const’ keyword.
Before we continue with Block Scope, let’s get a better understanding of these keywords.
The var
keyword has been with javascript for a while but let
and const
came in the launch of ES2015 (ES6) Javascript.
Variables declared with var
are usually hoisted. What this means is that regardless of the position that the variable is declared, it is lifted to the top of the scope.
A practical example;
Remember that when a variable is not declared, any reference to it would be a “Reference Error”,
// script.js
"use strict";
blogName = "Soshace";
console.log(blogName);
// Expected result : "ReferenceError: blogName is not defined";
What if the variable was declared with ‘var’ after the definition?
// script.js
"use strict";
blogName = "Soshace";
var blogName;
console.log(blogName);
// Expected result : "Soshace";
The variable ‘blogName’ was hoisted to the top of the scope which means it came before the declaration ‘blogName = “Soshace”‘. The scope here is global but the same rules apply for local scope such that the variable is lifted to the top of the scope.
With ‘let’ and ‘const’, we can prevent hoisting of variables. The previous code implemented with let
would be;
// script.js
"use strict";
blogName = "Soshace";
let blogName;
console.log(blogName);
// Expected result : "ReferenceError: Cannot access 'blogName'
// before initialization";
And there goes the Reference error.
The difference between let
and const
is that variables declared with the former can be later changed but the latter variables must be constant. Any attempt to change them would result in an error.
As we have seen now, let
and const
are the only declaration keywords that can ensure block scope because var
would hoist it’s variables to the top of the local or global scope.
This scope allows variables declared inside functions to be accessible by nested functions of that same function or accessible by local functions of the global scope.
When variables are referenced in a function, the JavaScript compiler searches for the variable from the function itself to the outer parts of the function until it gets to the global scope. If the variable isn’t found, then there’d be a reference worry error.
Using the same company scenario, a lexical scope can be likened to a case where the Financial Department has sub-departments. Those sub-departments would still have access to the privileges of the department itself.
Example code,
// script.js
var name = 'game'
function alterGlobalVar(varName) {
varName = 'altered global var';
var localVar = 'local';
return function() {
localVar = 'altered local var';
console.log(varName);
console.log(localVar);
}
}
alterGlobalVar(name)();
// Expected Results
// altered global var
// altered local var
From this program above, we can see that alterGlobalVar is lexically scoped to the global scope and the anonymous function in alterGlobalVar is lexically scoped to it thereby given it access to its parent’s variables.
These are the scopes available in the current version of Javascript.
These concepts are radical to JavaScript and important to understand if you want to approach more advanced topics. I hope you got a better understanding of JavaScript Scope and things around it.
Happy Coding!
#javascript #js #developer