Skip to content

Latest commit

 

History

History
413 lines (283 loc) · 11.1 KB

02-eng.md

File metadata and controls

413 lines (283 loc) · 11.1 KB

Data Types

In JavaScript there are 8 data types

Number (whole numbers or decimals)

String (chain of characters, meaning, text)

Boolean (indicates true or false)

Null (value not yet set by the user)

Undefined (value not yet set by JS)

Object (complex data structures - arrays, dates, literals, etc)

Symbol (used with objects)

BigInt (used to manipulate larger numbers)

1) Strings

Strings are kept between single or double quotes

'hello, world'
"hello, world"

Strings can be combined by using +

let hello = "hello"
let world = "world"

let greeting = hello + ' ' + world

To access a certain character we can open and close [ ] to specify the location we want. JS is a zero-based language, so we start counting with position zero.

If we want to access the index position of o in hello:

greeting[4]

Strings have properties and methods:

To specify a property we use . followed by the property.

.length is a property that counts the number of characters in a string.

let name = 'Ana'
name.length // 3

Functions that are restricted to an object scope are named method - and like functions, they execute a specific action.

.toUpperCase() turns every character in a string into upper case, without altering the original string.

name.toUpperCase() // ANA

.toLowerCase() turns every character in a string into lower case, without altering the original string.

name.toLowerCase() // ana

.indexOf('argument') searches for the index where the argument passed as a parameter shows up in a string. Returns the index and doesn't alter the original string in any way.

name.indexOf('n') // 1

.lastIndexOf('argument') searches for the last occurance of the string passed on as an argument. Returns the index of that occurance.

name.lastIndexOf('a') // 2

.slice( index1, index2 ) returns a slice of the string that begins in the first argument (which should be an index number) and goes up to one index value before the last argument (which should also be an index number). This method doesn't alter the original string.

name.slice(0, 2) // An

.replace( index1, index2 ) substitutes a character of a string by another. The first argument is the string that should be searched for, and the second one is the string it should replace it with. It doesn't alter the original string in any way. Notice that this method only alters the first occurance (to alter multiple occurances we should use Regex).

name.replace('n', 'd') // Ada

2) Numbers

Numbers can be stored in variables - decimals should use . instead of ,

const radius = 10
const pi = 3.14

Arithmetic Operators

* multiplier

+ addition

- subtraction

/ division

** exponent

Order of operation: obeys the same rules as math (1st parentheses, 2nd exponents or roots, 3rd multiplication or division, 4th addition and subtraction)

Increment operators

let postLikes = 10
postLikes++ 
// postLikes = postLikes + 1 
// 11

postLikes--
// postLikes = postLikes - 1 
// 9

postLikes += 10
// postLikes = postLikes + 10 
// 20

Operations that don't result in a number: NaN

(7 / 'hi') // NaN

String Concatenation with numbers: JS converts numbers to string, so the result of a concatenation between a string and a number will always be a string.

const likesMessage = 'The post has' + postLikes + 'likes.' // 'The post has 10 likes.'

3) Objects

Arrays are used to store a list of values that usually have some relation to each other

let heroes = ['Batman', 'Catwoman', 'Iron Man']

To change values writing over given positions in the array:

heroes[2] = 'SpiderMan'

It's possible to store different types of data in the same array:

const randomArray = ['Parker', 'Diana', 19, 18]

Array properties and methods

.length returns the amount of items in an array

let heroes = ['Batman, 'Catwoman', 'Iron Man']
heroes.length // 3

.join() returns a new string with every item in the array separated by a comma. It can receive an optional argument that acts as a separator instead of the comma.

heroes.join() // Batman,Catwoman,Iron Man

heroes.join('|') // Batman|Catwoman|Iron Man

.indexOf() returns the index of the given argument. If the argument doesn't exist in the array, it returns -1

heroes.indexOf('Batman') // 0

heroes.indexOf('Hulk') // -1

.concat() joins the array which invoked the method adding whatever was passed on as an argument. Doesn't alter the original array.

heroes.concat(['SpiderMan', 'Wolverine']) // ['Batman, 'Catwoman', 'Iron Man', 'SpiderMan', 'Wolverine']

.push() includes the items passed on as arguments in the original array. Returns the new number of items in the array after adding the arguments. It changes the original array, resulting in a value mutation.

heroes.push('Cyclops', 'Superman') // ['Batman, 'Catwoman', 'Iron Man', 'Cyclops', 'Superman']

.pop() removes the last item in the array and returns that item. Also modifies the original array.

heroes.pop() // 'Superman'

4 & 5) Null and Undefined

These two types are similar and both represent the lack of value. The difference between them is that null needs to be intentionally atributed.

Every time we declare a variable without atributing any value, JavaScript sets it to undefined

let emptiness 
console.log(emptiness)  // undefined

If we try to use undefined in a numerical expression, we get NaN

emptiness + 3 // NaN

To purposelly indicate that a variable doesn't have a value stored in it, null should be used.

let emptiness = null
console.log(emptiness)  // null

When we execute a mathematical operation using null it is interpreted as zero and doesn't throw an error.


emptiness + 3 // 3

6) Booleans

true and false are reserved words and data types that are used to verify conditions - whether a piece of code evaluates to true or false.

const email = '[email protected]'
const includes = email.includes('@')

console.log(includes)  // true

Comparison Operators

These are used to compare a value to another, and the comparison should return a boolean.

const age = 31

console.log(age == 31)  // true

Remember: = means attribution and == means comparison.

To write "different than", you should use !=

console.log(age != 31)  // false

Other number comparisons:

console.log(age > 10)  // true
console.log(age < 10)  // false
console.log(age <= 31>)  // true
console.log(age >= 31>)  // true

String comparisons:

const name = 'ana'

console.log(name == 'ana')  // true
console.log(name == 'Ana')  // false
console.log(name > 'bel' )  // false ('a' comes before 'b')
console.log(name > 'Ana' )  // true (lowercase comes before upper case)

Strict comparisons

When we used == we run the risk of having an equality in an expression that involves different types.

// 'Equal to' and 'different than'
console.log( 31 == 31 ) // true
console.log( 31 == '31' ) // true
console.log( 31 != 31 ) // false
console.log( 31 != '31' ) // false

To avoid this, we use === to have a strict comparison.

// 'Equal to, and with the same type' and 'different than, and with the same type'
console.log( 31 === 31 ) // true
console.log( 31 === '31' ) // false - since we're checking value AND type

console.log( 31 !== 31 ) // false
console.log( 31 !== '31' ) // true

That's why it's safer to stick with strict comparisons.

Type conversion

It's possible to convert a determined data type into another. In some moments that might come in handy to achieve specific results.

let score = '100'

console.log(score + 1) // 1001 adds strings to numbers resulting in another string.

It's possible to convert a string into a number and after that go through with the operation.

score = Number(score)  // reference 'score', reatribute the value turning a string into number, calling a constructor.

The type is modified when passing this string as an argument for a Number constructor.

console.log(score) // 101
console.log(typeof score) // number

Converting other types of data

const crazyConversion = Number('Apple') // NaN (math operation that doesn't make sense)

const convertedNumber = String(97) // '97' (string)

const booleanConversion == Boolean(10) // true (truthy value)

Truthy e Falsy Values

JavaScript atributes values true & false to determined values/types.

Falsy Values

false

0

"" ou ''

null

undefined

NaN

Any other value returns true

Primitive Types vs Reference Types

Primitive types are:

Numbers Strings Booleans Null Undefined Symbol BigInt

Reference types are:

Every type of object - Object literals - Arrays - Functions - Dates - Every other object there is

The difference between them is in the way they are stored in memory. When we create a primitive type and assign it to a variable, it is saved in the stack (a pile of different values in memory). These values can be accessed quickly, but space on the stack is limited.

When we create a reference type, it is stored in the heap. The heap has more space available to store larger and more complex objects (like literal objects and arrays), but it is a little slower.

They are two parts of the computer memory used for two different things.

When storing a primitive value in a variable, it stays in the stack and is accessed through the name of the variable. But when storing a reference type in a variable, such as an object, it is stored in the heap. The stack stores a variable pointing to the object in the heap.

This has implications for how we write our code. Here's what happens when we copy primitive types:

let scoreOne = 50  // primitive type, with variable (identifier) that allows us to access its value.

let scoreTwo = scoreOne // a copy of the primitive value is created on the stack at different positions in memory with different identifiers.

console.log(scoreOne)
console.log(scoreTwo)

// 50
// 50

scoreOne = 100  // when we change the value of the first variable the value in the scoreTwo variable is not affected.

console.log(scoreOne)
console.log(scoreTwo)

// 100
// 50

However, when creating copies of reference types, the behavior is different:

let userOne = {name: 'ana', score: 100} 
\\ it is a type of reference and therefore stored in the `heap`. In the stack we have a pointer stored in the userOne variable that points to the object created in the `heap`.

let userTwo = userOne 
\\ a new object was not created in the `heap`. The new variable stores a new pointer that points to the same object in the heap.

userOne.score = 50  

console.log(userOne.score)
console.log(userTwo.score)

\\ 50
\\ 50

When we create a copy of primitive values, we store them in different memory spaces in the stack. But when creating copies of reference values, we are only copying the pointer, which points to the same object in the heap. This means that when we modify the object, the change is also reflected in the copy, since the pointer is indicating the same object.