Front-end programming

JavaScript basics

javascript

Javascript

JavaScript is an interpreted (or just-in-time compiled) programming language with first-class functions.

 

It's a prototype-based, multi-paradigm, single-threaded, dynamic language, supporting object-oriented, imperative, and declarative (e.g. functional) programming styles.

 

It's most known as the scripting language for the Web.

JS and the web

When a web page is loaded in the browser, our code is running inside an execution environment (the browser tab).

 

A very common use of JavaScript is to dynamically modify HTML and CSS to update a user interface.

node.js

Although it started as a Web technology, JavaScript has since grown to be much more than that, and is now commonly found in both the client and server sides.

The most known tool for backend development in JS is Node.js.

 

Node is an open-source, cross-platform, back-end JavaScript runtime environment.

node.js

Node.js is built on Chrome's V8 engine (the JavaScript's interpreter built into the Google Chrome browser).

 

Node uses an event-drive, non-blocking I/O model that makes it lightweight and efficient.

Javascript pros and cons

PROS CONS
- Fast Execution
- Beginner friendly
- Well documented
- Language features like first-class functions, closures, prototypes, and object/array literals.
- Public code
- Compatibility issues (DOM)
- Language features like implied globals, complex this binding, type coercion, falsy values, function scope, and others.

obFuscators

Because JavaScript is deployed as source code, it will be publicly available.

 

One technique used to counteract this is to obfuscate the deployed code, making it vary hard to read and reverse-engineer.

// ORIGINAL CODE

console.log("Hello World!");
// OBFUSCATED CODE

var _0x5a9b=['1048708KvhfyS','Hello\x20World!','578650mpMCkd','693503mORuho','1548500vucrDU','867922wMLRDy','log','249059jGyHKq','1kVGFPF','118484jhQJRL'];var _0x24a4f2=_0x138d;
function _0x138d(_0x1dcd90,_0x44da07){return _0x138d=
    function(_0x5a9b54,_0x138dcf){_0x5a9b54=_0x5a9b54-0x74;var _0x3f9394=_0x5a9b[_0x5a9b54];return _0x3f9394;},_0x138d(_0x1dcd90,_0x44da07);}(var _0x5b0577=_0x138d;
      while(!![]){try{
          var _0x1b7606=-parseInt(_0x5b0577(0x77))+-parseInt(_0x5b0577(0x7c))+-parseInt(_0x5b0577(0x79))+parseInt(_0x5b0577(0x7a))*parseInt(_0x5b0577(0x75))+-parseInt(_0x5b0577(0x7b))+parseInt(_0x5b0577(0x74))+parseInt(_0x5b0577(0x76));
          if(_0x1b7606===_0xee4c5f)break;else _0x2a8c05['push'](_0x2a8c05['shift']());}
        catch(_0x2fb212){_0x2a8c05['push'](_0x2a8c05['shift']());}}}(_0x5a9b,0x82fa0),console[_0x24a4f2(0x78)](_0x24a4f2(0x7d)));

development environment

BROWSER

EDITOR

NODE.JS

Data types

Data Types

In JavaScript, a primitive is data that is not an object and has no methods. Everything that doesn't fall into this category is a structural data type, i.e., an object.

 

The available types are:

  • undefined 
  • boolean 
  • number
  • string
  • bigint
  • object
  • null

Dynamic typing

JavaScript is a loosely typed and dynamic language.

var a = 18; // a is a number
a = 2.6; // a is still a number
a = 'one'; // a is a string
a = true; // a is a boolean

Typeof

The typeof operator returns a string indicating the type of the operand.

var a = 18;

console.log(typeof a);
// expected output: "number"

console.log(typeof 'number');
// expected output: "string"

console.log(typeof true);
// expected output: "boolean"

console.log(typeof b);
// expected output: "undefined", because b hasn't been declared

var c = null;

console.log(typeof c);
// expected output: "object"

type coercion

Converting a value from one type to another is called casting when done explicitly, and coercion when done implicitly.

 

Type coercion is one of JavaScript's main features.

console.log(1 + 2 + '3'); // What's the result?

Coercion can be disabled on a boolean expression with the === operator, instead of the == operator.

Live coding

Variables, typeof, and type coercion

objects

objects

In computer science, an object is a value in memory which is possibly referenced by an identifier (variable).

 

In JavaScript, objects can be seen as a collection of properties.

var obj = { 
    a: 23, 
    b: 'Tokyo', 
    c: { 
        d: true
    } 
};

Access properties

There are multiple ways to access/modify an object's property.

var myObj = { 
    anotherObj: {
        a: 12, 
        b: 'bicycle'
      }, 
    2: 'sunglasses' 
};

console.log(myObj.anotherObj); 
// { a: 12, b: 'bicycle' }

console.log(myObj['anotherObj']['a']); 
console.log(myObj.anotherObj.a); 
// 12

console.log(myObj[2]);
// sunglasses

console.log(myObj.2);
// ERROR

Add new properties

It is possible to add a new property to an already declared object.

var myObj = { 
    anotherObj: {
        a: 12, 
        b: 'bicycle'
      }, 
    2: 'sunglasses' 
};

myObj.newProperty = 'wow';


Object.defineProperty( myObj, "anotherKey", {
    value: "used if we want to have more control over our property's behaviour",
    writable: true,
    enumerable: true,
    configurable: true
});

delete properties

It's also possible to delete a property.

var myObj = { 
    anotherObj: {
        a: 12, 
        b: 'bicycle'
      }, 
    2: 'sunglasses' 
};

delete myObj.anotherObj;

live coding

Objects

functions

Functions

In JavaScript, functions are ordinary objects with the
additional capability of being callable.

function returnRandomNumber(min, max) {
    return Math.random() * (max - min) + min;
}

function printName(name) {
    console.log(name);
}

printName.property = "hello world";

typeof returnRandomNumber;     // "function"
typeof returnRandomNumber();   // "number"
typeof printName.property; // "string"
typeof printName();	// "undefined"

Arguments

Arguments is an array like object containing all passed arguments into the function.

function action(a) {
    console.log(a + 1, arguments);
}

// Can you guess the output?
action();
action(1);
action('ey');

Arguments

Arguments is an array like object containing all passed arguments into the function.

function action(a) {
    console.log(a + 1, arguments);
}

// Can you guess the output?
action();
action(1);
action('ey');

Arguments

Arguments contains a numerical property for each argument passed to the function.

 

The arguments object IS NOT an array!

function myFunction(x, y) {
    console.log(x);
    console.log(y);

    for (var i = 0; i < arguments.length; i++) {
        console.log(arguments[i]);
    }

    console.log(arguments['0']);
}

// what will the output be?
myFunction(1, 2, 3, 4);

Arrow functions

Arrow functions provide a compact syntax for writing functions.

var operation = (num1, num2, operation) => {
    return operation(num1, num2);
} 

var adding = (num1, num2) => {
  return num1 + num2;
}

console.log(operation(2, 5, adding));
// 7

Higher order function

A higher order function returns a function or receives one as argument.

var doOperation = (num1, num2, operation) => {
    return operation(num1, num2);
} 

var adding = (num1, num2) => {
  return num1 + num2;
}

console.log(doOperation(2, 5, adding));
// 7

doOperation() is a higher order function

operation() is a callback function

Higher order functions

A higher order function returns a function or receives one as argument.

// RETURNING A FUNCTION
var multiplication = (num1) => {
    return function (num2) {
        return num1 * num2;
    }
}

var double = multiplication(2);

console.log(double(5));
// 10

Live coding

Functions

arrays

Arrays

Arrays are list-like objects. These objects have methods to perform traversal and mutation operations.

 

An array's length can change at any time and data can be stored at non-contiguous locations.

var players = ['Kane', 'Chiesa', 'Sterling', 'Insigne'];

console.loh(players.length);
// 4

Access an array item

Array items are accessed using their index position.

var players = ['Kane', 'Chiesa', 'Sterling', 'Insigne'];

console.log(players[0]);
// Kane

console.log(players[players.length - 1]);
// Insigne

players[0] = 'Spinazzola';
console.log(players[0]);
// Spinazzola

console.log(players.at(1));
// Chiesa

ADD an array item

Array items can be added directly or using an array method.

var players = ['Kane', 'Chiesa', 'Sterling', 'Insigne'];

// DIRECTLY
players[4] = 'Spinazzola';
players[10] = 'Verratti';

// ADDING TO THE END OF THE ARRAY
players.push('Saka');

// ADDING TO THE BEGINNING OF THE ARRAY
players.unshift('Rashford');

Removing an array item

Array items can be removed using array methods.

var players = ['Kane', 'Chiesa', 'Sterling', 'Insigne', 'Spinazzola', 'Saka'];

// REMOVING FROM THE END OF THE ARRAY
players.pop();

// REMOVING FROM THE BEGINNING OF THE ARRAY
players.shift();

// REMOVE FROM SPECIFIC INDEX
var position = players.indexOf('Sterling');
players.splice(position, 1);

// REMOVE MULTIPLE ITEMS BY INDEX
let removedItems = players.splice(1, 2);
// this will remove two items starting at index 1

console.log(players);
// ['Kane', 'Insigne', 'Spinazzola', 'Saka']

console.log(removedItems);
// ["Chiesa", "Sterling"]

looping an array

Array items can be removed using array methods.

var players = ['Kane', 'Chiesa', 'Sterling', 'Insigne', 'Spinazzola', 'Saka'];

players.forEach(function(item, index) {
  console.log(item, index)
});

// Kane 0
// Chiesa 1
// Sterling 2
// ...

SOrting

var months = ['March', 'Jan', 'Feb', 'Dec'];

months.sort();
console.log(months);
// ["Dec", "Feb", "Jan", "March"]

const array1 = [1, 30, 4, 21, 100000];

array1.sort();
console.log(array1);
// [1, 100000, 21, 30, 4]

MAP-Filter-Reduce

var result = players
    .filter(player => player.startsWith('S'))
    .map(player => player.toUpperCase())
    .reduce((acc, player) => acc + player + ' ', '');

console.log(result);

other operations

// CONCATENATION
var array1 = ['a', 'b', 'c'];
var array2 = array1.concat(['d', 'e', 'f']);

console.log(array2);
// ["a", "b", "c", "d", "e", "f"]


// JOINING ELEMENTS INTO A STRING
console.log(array2.join());
// a,b,c,d,e,f

console.log(array2.join('-'));
// a-b-c-d-e-f


// RERVERSING THE ELEMENTS IN AN ARRAY
var reversed = array1.reverse();

console.log('reversed:', reversed);
// "reversed: ["c", "b", "a"]"

console.log('array1:', array1);
// "array1: ["c", "b", "a"]" 

other operations

var brands = ['Hermes', 'Chanel', 'Prada', 'Burberry', 'Versace'];

// SLICING
console.log(brands.slice(2));
// ["Prada", "Burberry", "Versace"]

console.log(brands.slice(1, 5));
// ["Chanel", "Prada", "Burberry", "Versace"]

console.log(brands.slice(-2));
// ["Burberry", "Versace"]


// FILLING
console.log(brands.fill('', 2));
// ["Hermes", "Chanel", "", "", ""]
// 
console.log(brands.fill('', 2, 4));
// ["Hermes", "Chanel", "", "", "Versace"]

other operations

var array1 = [10, 122, 2, 189, 442];

// FINDING AN ELEMENT
var result1 = array1.find(element => element > 10);
console.log(result1);
// 122

var result2 = array1.find(element => element > 500);
console.log(result2);
// undefined

// CHECK IF ELEMENT IS PRESENT 
console.log(array1.includes(2));
// true

Live coding

Arrays

Exercise

Arrays (Pass The Tests)

scope

Scope

Scope refers to the region of our code where a variable is valid/accessible.

Global scope

Global variables live through the entire execution of the program,
and can be accessed and altered anywhere.

 

Variables defined outside a function or without the var keyword will be bound to the Global Scope.

var name = 'Sarah'; // global variable

function doStuff() {
    console.log(name); // Sarah
    doSomethingElse();
    console.log(nam2); // Liam
}

function doSomethingElse() {
    name2 = 'Liam'; // implied global, as soon as doSomethingElse is invoked
}

STRICT MODE

Before ES6 existed, JavaScript had a way to prevent implied globals: strict mode.

"use strict";

var name = 'Sarah'; // global variable

function doStuff() {
    console.log(name); // Sarah
    doSomethingElse();
    console.log(name2); // WON'T EVEN GET HERE
}

function doSomethingElse() {
    name2 = 'Liam'; // ERROR
}

Local scope

Local variables exist only within the function body
of which they are defined.

 

In JavaScript, local scope is bound to function, not block!

var name = 'Sarah'; // global variable

function doStuff() {
    console.log(name); // Sarah
    doSomethingElse();

    if (name) {
        var exists = true;
    }

    console.log(exists); // true
    console.log(name2); // ERROR
}

function doSomethingElse() {
    var name2 = 'Liam'; // local variable
}

Lexical scope

In JavaScript, a variable defined outside a function can be accessible inside another function defined after the variable declaration. The opposite is not true.

var firstFunction = (par1) => {
    var mySpecialVar = "hi!";
    return function (par2) {
        console.log(mySpecialVar);
        console.log(par1);
        console.log(par2);
    }
}

var secondFunction = firstFunction(2);

secondFunction(2); // hi! 2 2 
// even though mySpecialVar is part of the firstFunction's local scope
// because we need its value in secondFunction, it becomes a part of secondFunction's lexical scope

hoisting

Declarations are always processed before any code is executed. This is called hoisting.

sayHelloToJonny(); // prints Hello Peter

function sayHelloToPeter() {
    var name = "Peter";
    console.log("Hello", name);
}

var vs let vs const

Variables declared with let or const are not hoisted.

 

Variables declared with const can't be reassigned.

// DECLARING A VARIABLE IN ES5
var studentName = "Philip";

// DECLARING A VARIABLE IN ES6
let anotherStudentName = "Mark";
const yetAnotherStudentName = "James";

Live coding

Scopes and Hoisting

wrappers

Primitive wrappers

JavaScript has the Boolean, Number and String objects that wrap around primitive values.

var name = "Rod";
console.log(name.toUpperCase()); 
// JS creates a wrapper --> new String("Rod").toUpperCase();

Live coding

Primitive Wrappers

JavaScript Basics

By Soraia Veríssimo

JavaScript Basics

  • 1,658