JavaScript Backend basics

2.5

The following article is to get started with back end development using JavaScript. This article would cover the basics and rules used in JavaScript.

JavaScript Engine

Each browser has its own JavaScript engine which is used to support the JavaScript scripts in order for them to work properly. Below are the names of the JavaScript engines used in some of the most popular browsers out there.

  • Chrome: V8
  • Firefox: SpiderMonkey
  • Safari: JavaScript Core
  • Microsoft Edge/ Internet Explorer: Chakra

ECMA Script StandardThe ECMA Script standard is a trademark scripting-language specification standardized by European Computer Manufactures Association. The ECMA Script standard sets the standard for JavaScript which is used throughout the web browsers available out there.

Types definitions in JavaScript

Dynamic Typing: The interpreter figures out the type of the variable dynamically based on certain conditions.

Primitive Data Types: The primitive data types are the data types which have no methods attached to it i.e. some defined methods cannot be used with them and they are used in isolation. Though there are ways to use those methods by wrapping these primitive data type variables (covered in the next article). The following are the data types that comes under the primitive category:

  1. undefined:- If variable exists but is not defined the it is categorized under undefined.
  2. null:- If variable exists but is not explicitly set the it comes under null category.
  3. boolean:- The Boolean data type is to define if a variable is True or False.
  4. number:- number is the data type to define a number which can be integer, floating point, double. The only problem here is that we have to allocate a memory equivalent to a double variable every time we define a number.
  5. string:- This is used to define string values of a character.
  6. symbol:- This is a special data type which is new in ECMA Script 6. The data type “symbol” is a primitive data type having the quality that values of this type can be used to make object properties that are anonymous.

Object
Everything in JavaScript is an object. That is each variable, string, array or any other structure that we know comes under the category of object. Java Script object can be understood by almost every language and are easy to read.

Creating objects: – There are 3 ways to create objects:
1. Using the Object() Constructor
1

2.Using Object literal
2

3. Directly specifying the values
3

Coercion: What we call typecasting in C, C++, Java, it is called coercion in JavaScript.
Coercion is of two types:

  •  Explicit Coercion
    Explicit coercion is the process by which we explicitly define a variable to a data type.
    4
  • Implicit Coercion Implicit Coercion is the process by which the interpreter dynamically type casts the variable under certain conditions.
    5

Scope

Variable lifetime: – The variable lifetime is from where they are declared until their function ends. If no function is defined then scope of the variable is global.

Hoisting: – Function definitions are hoisted but not variable declarations. This means that when a function is declared, it is usable from anywhere within your code.

Example of hoisting: –
6

The above function is executed successfully when called. But if we call the function first and then define it, then also it is successfully executed. This is called function hoisting.

7

However variable initialization are not hoisted.
8

The above example is the part which proves that variable hoisting is not possible in JavaScript.
But look at the next example which is another type of hoisting defined in JavaScript.

9

The above output errors as undefined and as we know that undefined type is when the variable exists but is not defined. So the question is how does the variable exists even if it is declared and initialized later?
This is another type of hoisting just like function hoisting i.e. the variable ‘x’ is available to us previously.

The JavaScript engine works in two different phases:

  1. Creation Phase: Before executing the code, the engine reads through the entire file and will throw a syntactic error if one is found. While it does that, any function definitions will just be saved in memory. Any variable initialization will not be run but variable names will be declared.
  2. Execution Phase: The execution phase is the phase in which the code is run and hence the above variable hoisting example errors as undefined since in creation phase, the variable has been declared but not defined in the creation phase.

That’s it for this article. We’ll be covering some advanced topics in the next follow-up article.

This article is contributed by Anirudh Acharya. If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to contribute@geeksforgeeks.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.

Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above.

GATE CS Corner    Company Wise Coding Practice

Recommended Posts:



2.5 Average Difficulty : 2.5/5.0
Based on 2 vote(s)










Writing code in comment? Please use ide.geeksforgeeks.org, generate link and share the link here.