/js-es6

Primary LanguageJavaScript

Javascript/ECMAScript 6

Javascript > Programming Language ECMAScript > Specification

Dynamically/weakly typed (not type safe)
Object Oriented
Garbage collection done automatically
Versatile Language runs in different platforms

JavaScript Engines
FireFox: SpiderMonkey
Google : v8(Used in node)

Variables

  • Default value of variables are undefined
  • Case-sensitive
  • Should be meaningful
  • Cannot be a reserved keyword
  • Cannot start with a number (1name)
  • Cannot contain a space or hyphen (-)
  • Use camel notation for naming variables

Use const if you don't want to reassign a variable

In JavaScript, variables can hold two types of data: primitive types and reference types. The main difference between them is in how they are stored and passed around in memory.

Primitive types, such as strings, numbers, booleans, null, and undefined, are stored directly in the variable's memory space. When you assign a new value to a primitive type variable, the old value is replaced with the new one.

On the other hand, reference types, such as objects and arrays, are stored in memory as a reference to their location. When you assign a reference type to a variable, you are actually assigning a pointer to the object or array, rather than the value itself. This means that when you pass a reference type as an argument to a function or assign it to another variable, you are passing a reference to the same object or array, not a copy of it.

Primitive/Value Types

  • String
  • Number
  • Boolean
  • undefined
  • null (Used to explicitly clear the value of a variable)
  • Symbol (new in ES6)

Reference Types

  • Object

  • Function

  • Array

      let c = [1, 2]
      let d = c
      console. log(`c === d ${c === d`) //true
      console. log(`c == d ${c == d}`) //true
    

True because they point to the same memory address/reference

    let c = [1, 2]
    let d = [1, 2]
    console. log(`c === d ${c === d`) //false
    console. log(`c == d ${c == d}`) //false

d is a seperate memory address and when checked if equal it will be false Reference is passed not the value

Objects

let person = { name: 'Tanushka', age: 25 };

Dot notation can be used to assign and read values(shorter and concise) person.name = 'Tanu';

Bracket Notation person['name'] = 'Tan';

This is best used for dynamic assignment on run time let selection = 'name'; person[selection] = 'T';

Arrays

Array is an object Array is a data structure that is used to represent a list of items Length is dynamic Can be any type(Elements doesn't need to be the same type)

let colors = ['red', 'green'] colors[2] = 'green'

console.log(colors[1])

Functions

function greet(name) { // name is the Parameter of the function
    console.log('Hello World' + name);
} // ; not required

greet('Tanu'); // Argument is passed

Types of functions
  • Performs a task
  • Calculates a value and return it

Operators

By using operators and variables we can create expressions, by using expression we can create algorithms

Operators variables -> expressions -> algorithms

  • Arithmetic
  • Assignment
  • Comparison
  • Logical
  • Bitwise

Arithmetic operators

  • Addition +

  • Subtraction -

  • Multiplication *

  • Division /

  • Remainder of division % Modulo

  • Exponentiation ** > ( x ** y ) x to the power of y

  • Increment ++

  • Decrement --

    let x = 10; console.log(++10); // output 11 console.log(10++); // output 10

Assignment operators

let x = 10;
x++; // x = x + 1;
x += 5; // x = x + 5;

x *= 4; // x = x * 4;

Comparison operators

let x = 1;

Relational

  • Greater than >
  • Greater than or equal to >=
  • Less than <
  • Less than or equal to <=

Equality

  • Strict Equality === (Checks if type and value are equal) Ensures that both values have same types and values 1 === 1 // true '1' === 1 // false

  • Lose Equality == (Will convert the type and checks the value) 1 == 1 //true '1' == 1 //true

Not equal !==

Ternary

let points = 110 let type = points > 100 ? 'Gold' : 'Silver' //Gold

Logical operators

  • Logical AND && Returns TRUE if both operands are true
  • Logical OR || Returns TRUE if one of the operands is true
  • Logical NOT ! Returns the opposite
  • Can be used with non-booleans as well(truthy or falsy)
  • Falsy: undefined, null, 0 ,false, '', NaN
  • Anything that is not falsy is truthy
  • Short-circuiting: It will return the first value which is truthy when evaluating from left to right (false || 1 || 2 || 3) //Output 1

BitWise operators

  • BitWise OR | (Add)
  • BitWise AND & (Check)

1 = 00000001
2 = 00000010

1 | 2 // 3 = 00000011
1 & 2 // 0 = 00000000

Operator precedence

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Operator_Precedence

Control Flow

Conditional statements

  • If...else (If we only have one statement we don't need to use {})
  • Switch...case (Need to use break; in each switch statement to jump out of the block)

Loops

Repeats action multiple times until condition is met

  • For for (initialExpression; condition; incrementExpression;)
  • While initialExpression while(condition) {... incrementExpression}
  • Do...while initialExpression do{... incrementExpression} while(condition) do block is executed at least once

Iterate over properties of an object or elements in an array

  • For...in for (let key in object) console.log(key, object[key]) Used for objects but can be used for arrays as well
  • For...of for (let element of array) (color of colors)

break; terminates the current loop/ jump out of a loop continue; terminates execution of the statements in the current iteration and jump to the next iteration of the loop

Objects

  • Purpose of an object is to group related variables and functions
  • A function that is a part of an object is called a method
  • Objects are dynamic, we can add or delete new properties and methods
  • const objects cannot be reassigned but can add/delete properties and change the object
  • Every object has a constructor property(it references to the function that was used to create the object)
  • If one or more methods(behavior) are in the object, object literal syntax is not a good way to create objects
  • When there are one or more methods in an object, the best way to create an object is factory or constructor functions
  • Functions are objects
  • Objects are not iterable

Factory functions

  • Produce object instances without diving into the complexities of classes, and the new keyword

  • It simply returns an object

  • Camel Notation createCircle()

  • Constructor property of circle1 is Object() this is an internal constructor function index.js:107

    function createCircle(radius) { return { radius, draw() { console.log('Draw'); } } } const circle1 = createCircle(1);

Constructor functions

  • Pascal notation Circle()

  • Under the hood the new keyword will,

  • create an empty object

  • set this to point to the empty object

  • return the object

  • Constructor property of circle object is Circle(radius) {...}

    function Circle(radius) { this.radius = radius; this.draw = function () { console.log('Draw circle'); } } const circle = new Circle(1); circle.draw();

Enumerating Properties of an Object

We can use for...in for (let key in object) console.log(key, object[key]) to iterate properties/methods in an object
We can also use for...of with for (let key of Object.keys(obj)) which returns a keys string array [] and for (let entry of Object.entries(obj)) which returns each key value pair as an array To check if a given property is in an object if ('radius' in circle)

Cloning an object

Old way

const another = {};
for (let key in circle)
another[key] = circle[key]; // another['radius'] = circle['key'];

Object.assign

will take a target object(can be an empty object or an existing object) as the first argument and will take one or more source objects.
This method will copy all the properties/methods of the source objects to the target object
Can be used to clone an object or to combine multiple objects

const another = Object.assign({}, circle); //empty object
const another = Object.assign({color: 'green'}, circle); //existing

Spread operator ...

Spreads an object(get all properties/methods) and put them into another object

const another = { ...circle};

Value(Primitives) vs. Reference(Objects) types

Primitives are copied by their value

let x = 10;
let y = x; // independent copy of the value
x = 20
//Output 
x --> 20
y --> 10

Objects are copied by their reference /address

let x = {value : 10};
let y = x; //copies the reference in memory like 1234
x.value = 20
//Output
x = {value: 20}
y = {value: 20}

When checking for equality between objects reference is checked


Math: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math
String: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String
Javascript has String primitive and String object.
Javascript engine will wrap the primitive string with a String object internally, so we can use the methods Template Literals using back tick
Use multi-line strings and string interpolation Date: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date


Arrays

Adding elements

const numbers = [3,4]; //[3,4]

//End
numbers.push(5,6); // [3,4,5,6]

//Beginning
numbers.unshift(1,2); // [1,2,3,4,5,6]

//Middle (start position, delete count, new items)
numbers.splice(2, 0, 'a', 'b'); // [1, 2, "a", "b", 3, 4, 5, 6]

Removing Elements

const numbers = [1,2,3,4,5,6]; //[1,2,3,4,5,6]
//End
const last = numbers.pop(); // numbers:[1,2,3,4,5] last: 6

//Beginning
const first = numbers.shift(); // numbers:[2,3,4,5] first: 1

//Middle (start position, delete count, new items)
numbers.splice(2, 2); // [2, 3]

//Deleted elements are returned as an array and can be fetched
let val = numbers.splice(1, 1)[0];

Emptying an array

let numbers = [1, 2, 3, 4, 5, 6];
let another = numbers;

//Solution 1: Will not work if there are multiple references. numbers will be pointing to a new array
numbers = [];

//Solution 2: Best solution
numbers.length = 0;

//Solution 3
numbers.splice(0, numbers.length);

//Solution 4: Have performance impact
while (numbers.length > 0)
    numbers.pop();

Combining, copying and slicing arrays

let one = [1, 2, 3];
let two = [4, 5, 6];

//Combine
let combined = one.concat(two); // [1, 2, 3, 4, 5, 6]
const combined2 = [...one, ...two]; //Using the spread operator

//Copy
const copy = [...combined];
let copy1 = combined.slice(); //[1, 2, 3, 4, 5, 6]

//Slice
let sliced1 = combined.slice(2); //[3, 4, 5, 6]
let sliced2 = combined.slice(2,4); //[3, 4]

If the values are primitive they will be copied by values to the output array
If the values are reference type(objects) the reference will be copied

Joining arrays

const joined = numbers.join(',');

Can use split and join Default comma is used as separator

Mapping arrays

Mapping returns a new array

const mapped1 = filtered.map(number => {
return `<li>${number}</li>`;
});

Reducing an array

  • Reducing elements of an array to a single value

  • Reduce method have 2 arguments

  • 1st is a callback function

  • 2nd is the initial value of the accumulator

  • If we don't initialize the accumulator it will take the 1st element as accumulator and the
    2nd element as currentValue

    numbers.reduce((accumulator, currentValue) => { return accumulator + currentValue; }, 0);

    const reduced1 = numbers.reduce((accumulator, currentValue) => accumulator + currentValue);

Iterating an array

for (let number of numbers)
console.log(number);

numbers.forEach((number, index) => console.log(index, number)); //when using for each we can also get the index

Sorting arrays

numbers.sort();
numbers.reverse(); //reverses the order(does not sort)

Checking elements

Returns a boolean, will not check all elements in an array will return if matches

numbers.every() //Checks if every element matches the given criteria

numbers.some() //Checks if at least one element matches the given criteria

Finding Elements

Primitive types

[1, 2, "a", "b", 3, 4, 5, 6]
numbers.indexOf('a') // 2
numbers.indexOf('d') // -1
numbers.indexOf(4) !== -1 // true
numbers.includes(5) //true
numbers.indexOf('a', 3) // Passing search starting index from(Start search from index 3) 

Reference types(Objects)

const course = courses.find(function (course) {
    return course.name === 'a';
});
const course = courses.findIndex(function (course) {
    return course.name === 'c';
});

Arrow functions

When passing a function as a callback/predicate function, or an argument we can use arrow function syntax

  • Remove the function keyword and ;

  • Add the arrow => to separate the parameters of the function from its body

  • If we only have one parameter we can remove the parenthesis also ()

  • If there are no parameters we have to pass empty parenthesis ()

  • If the function is a single line of code and is returning a value we can remove the curly braces as well {}

  • If we are returning an object (n => {value: n}) we have to surround it using () (n => ({value: n}) because by default {} is treated as a code block

    const course = courses.find(function (course) { return course.name === 'a'; }); //Using arrow function const course = courses.find(course => course.name === 'a');

Chaining of methods

A new array is returned every time, so we can chain the methods

const filtered1 = numbers
    .filter(number => number > 0)
    .map(number => `<li>${number}</li>`)
    .join(`\n`);

Functions

Function Declaration (; is not required)

Can be called before it is defined (due to hoisting)

function walk() {
    console.log('walk');
}

Function Expressions

Declaring a variable/constant and then setting it to a function
Cannot be called before it is defined/initialized

Anonymous Function Expression

let run = function () {
    console.log('run');
}; // When declaring a variable/constant we need to terminate it with a ;
let x = 1;

run();
let move = run; // move and run are referencing the same anonymous function (one object in memory)
move();

Named Function Expression

let jog = function jogging() {
    console.log('jog');
};
  • Process of moving all the function declarations to the top of the file

  • JavaScript only hoists declarations, not initializations

  • If a variable is declared and initialized after using it, the value will be undefined

  • Initializations using let and const are also not hoisted

    run(); // Throws ReferenceError exception let run = function () { //initialization of run is done after console.log('run'); };

Below will work due to hoisting the function declaration

walk(); //logs walk
function walk() {
    console.log('walk');
}

Arguments

  • It's an object

  • Keys of the arguments object are the indexes of the arguments passed to the function

    function sum(a, b) { console.log(arguments); //arguments object with 1, 2, 3, 4, 5 return a + b; } console.log(sum(1, 2, 3, 4, 5)); //3

    function total() { console.log(arguments); let total = 0; for (let value of arguments) total += value; return total; } console.log(total(1, 2, 3, 4, 5)); //15

Rest operator (...)

  • Similar to spread operator when used with arrays to spread an array(take individual elements)

  • When (...) used with a parameter of a function it is called the rest operator

  • We can pass varying number of arguments to a function

  • The rest operator will put all the arguments to an array

  • Rest parameter should be the last parameter in a function

    function multiply(multiplier, ...args) { //multiplier and REST of the parameters/arguments console.log(args); //[2, 3, 4, 5, 10] const total = args.reduce((a, b) => a + b); return total * multiplier; } console.log(multiply(1, 2, 3, 4, 5, 10)); //24

Default Parameters

If you give a parameter a default value, you have to give default values to all the parameters after that

function interest(principal, rate = 3.5, years = 5) {
    // rate = rate || 3.5;
    // years = years || 5;
    return principal * rate / 100 * years;
}

console.log(interest(10000 ));

Getters and Setters

  • getters => access properties (Read only)

  • setters => change (mutate) properties

  • By using getters we can access object methods as a property without () => Object.method

    const person = { firstName: 'Tanushka', lastName: 'Bandara', // fullName: function() {} // Old syntax get fullName() { return Method: ${this.firstName} ${this.lastName}; }, set fullName(fullName) { let names = fullName.split(' '); this.firstName = names[0]; this.lastName = names[1]; } };

    person.fullName = 'T B'; //setter //console.log(person.fullName()); //without getter console.log(person.fullName); //with getter

Try and catch

Error handling Try block can have one or more statements In the catch block we can get the thrown error object and handle it

const e = new Error(); //plain javascript object
throw e; //the moment we throw it, its referred to as an exception

...
set fullName(fullName) {
    if (typeof fullName != 'string')
        throw new Error('Full name is not a string');
    let names = fullName.split(' ');
    if (names.length !== 2)
        throw new Error('Enter a valid name')
}
...

try {
    person1.fullName = ''; //setter
} catch (e) {
    console.error(e);
}

Local vs Global Scope

  • Scope of let and const is limited to the block in which they are defined
  • In functions, if statements, loops limited to the scope inside to the block
  • Global scope is when variables are defined outside(Not in any code blocks)
  • Local variables/constants takes precedence over global variables/constants
  • Better not to declare global variables/constants

Let vs Var

  • Let variables are only accessible inside the code block in which they are defined
  • Var scope is not limited to the code block in which they are defined, it's limited to the function in which it's defined
  • var => function-scoped
  • let, const => block-scoped
  • When using var to define a variable outside a function, it will create a global variable which is attached to the window object in the browser

When a function is defined it is technically a global function, and it is attached to the window object. We can use modules to encapsulate and prevent functions from attaching to the window object.

This keyword

The object that is executing the current function

  • If a function is a method(function) of an object, this references that object itself
  • If a function is a regular function(not part of a object) this references the global object(window object in the browser and global object in node)
  • If we call a function using the new operator(constructor functions), this references to a new empty object

1.Hoisting: Js compiler will move variable declarations and functions to the top

2.Call stack: LIFO: When we say that the call stack, operates by the data structure principle of Last In, First Out, it means that the last function that gets pushed into the stack is the first to be pop out, when the function returns.

3.IIFE: Immediately invoking function expression (function() { var name = 'Tan'; }) ();

4.Scope

  • Global scope
  • Function scope

JavaScript let The let statement allows you to declare a variable with block scope

5.callbacks, promises and async await*/