Array

A collection of stuff.

Arrays are a collection of values. It can be a set of numbers, strings or objects. It is common that it holds only one of the types.

let myArr = [] // empty array

let myArr2 = [1, 5, 8, 2, 5, 2, 4, 3, 1] // array of numbers

let myArr3 = ['a', 'b', 'c', 'z', 'foo'] // array of strings

let myArr = [1, 0, 'x', 19, 'f', '22', 'some other stuff'] // array of mixed values

Arrays are declared with brackets [ ]. All the values goes inside the brackets and are separated by comma ,.

push

let myArr = []

myArr.push(1)
myArr.push(10)
myArr.push(11)
myArr.push(13)
myArr.push(6)

console.log(myArr)

This should output the values: [ 1, 10, 11, 13, 6 ].

We use the array method called push to push new values to the end of the array.

We can now get the values one by one, by using the index position of that value.

let myArr = ['one', 2, 3, 'four']
//             0    1  2     3
console.log(myArr[0]) // this outputs 'one'
console.log(myArr[2]) // this outputs 3
console.log(myArr[3]) // this outputs 'four'

Array indexes starts with 0. So if we want to get the first value, we have to use index position 0 to get that value.

IndexOf

By using indexOf, we can find the index position of that element in the array.

let myArr = ['one', 2, 3, 'four']
console.log(myArr.indexOf('four')) // this outputs 3

Since array indexes starts with 0, the string ‘four’ have the index of 3.

If the indexOf method can not find the value in array, it just returns -1.

Length

Now that we know how to add stuff to our array, we can count them by using the length property.

let myArr = ['one', 2, 3, 'four']
console.log(myArr.length) // this outputs 4

Let us combine the if statement and arrays.

let myArr = []

function isItEnough(inputArr) {
  let returnValue = 'No'
  if (inputArr && inputArr.length >= 3) {
    returnValue = 'Yes we have 3 or more values'
  }
  return returnValue
}

console.log(isItEnough(myArr)) // this outputs 'No'

myArr.push(1)
myArr.push('x')

console.log(isItEnough(myArr)) // this outputs 'No'

myArr.push('y')

console.log(isItEnough(myArr)) // this outputs 'Yes we have 3 or more values'

As you can see in the code above, we declare and array on line 1. Then we made a function isItEnough and passed the array as input to check if we have 3 or more values. If you look at the line 5 in the if statement expression, we use &&. That means AND. So first we check if we have some value in inputArr and then by using the AND operator we ask if it also has the length of 3 or more. If we don’t have any value for inputArr, the rest of the checks inside the if statement expression is not called, and we jump right out of the if scope.

Array have a lot more methods like push and properties. But let us not go too fast. I’m going to explain more about them in combination of other parts in this book later on.

Concat

You can combine two arrays by using concat method.

let myArr = [1, 2, 3]
let myArr2 = [4, 5, 6]
let myArr3 = myArr.concat(myArr2)
console.log(myArr3) // this outputs [ 1, 2, 3, 4, 5, 6 ]

You can also use the spread operator to combine arrays.

let myArr = [1, 2, 3]
let myArr2 = [4, 5, 6]
let myArr3 = [...myArr, ...myArr2]
console.log(myArr3) // this outputs [ 1, 2, 3, 4, 5, 6 ]

Sort

You can sort the array with sort function, but it is some caveats.

Javascript sort numbers as it was a textual and some letters might not sort in right place.

// Wrong way of sorting numbers

let myArr = [1, 20, 3, 11, 12, 2].sort()
console.log(myArr) // this outputs [ 1, 11, 12, 2, 20, 3 ]

Instead, we can make our own comparing method to do this in a right way.

function compareNumbers(a, b) {
  return a - b;
}

let myArr = [1, 20, 3, 11, 12, 2].sort(compareNumbers)

console.log(myArr) // this outputs [ 1, 2, 3, 11, 12, 20 ]

And to make this descending, we can use the method reverse()

function compareNumbers(a, b) {
  return a - b;
}

let myArr = [1, 20, 3, 11, 12, 2].sort(compareNumbers).reverse()

console.log(myArr) // this outputs [ 20, 12, 11, 3, 2, 1 ]

Let’s try to add mix some strings in there to see the danger of sorting with mixed values.


function compareNumbers(a, b) {
  return a - b;
}

let myArr = ['0', 'something 1', 'something 2' ,'5' , 1, 20, 3, 11, 12, 'x', 'a', 2 ,0].sort(compareNumbers)

console.log(myArr) // this outputs [ '0', 'something 1', 'something 2', 0, 1, 2, 3, '5', 11, 12, 20, 'x', 'a' ]

Now this is confusing stuff there.

You can read more about the sort function here Sort on MDN

In this case you have to first figure out how you want it sorted and use our compareNumbers function to sort in the right way. Or just filter out non-numeric values from the array first. You can use the filter method (explained in chapter 2) to do this.