parent
							
								
									fc0b62b7f6
								
							
						
					
					
						commit
						27c857d29d
					
				| @ -0,0 +1,15 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| 
 | ||||
| <head> | ||||
|     <title>30DaysOfJavaScript: 03 Day</title> | ||||
| </head> | ||||
| 
 | ||||
| <body> | ||||
| 
 | ||||
|     <!-- import your scripts here --> | ||||
|     <script src="./scripts/main.js"></script> | ||||
| 
 | ||||
| </body> | ||||
| 
 | ||||
| </html> | ||||
| @ -0,0 +1 @@ | ||||
| // this is your main.js script
 | ||||
| @ -0,0 +1,15 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| 
 | ||||
| <head> | ||||
|     <title>30DaysOfJavaScript</title> | ||||
| </head> | ||||
| 
 | ||||
| <body> | ||||
| 
 | ||||
|     <!-- import your scripts here --> | ||||
|     <script src="./scripts/main.js"></script> | ||||
| 
 | ||||
| </body> | ||||
| 
 | ||||
| </html> | ||||
| @ -0,0 +1 @@ | ||||
| // this is your main.js script
 | ||||
| @ -0,0 +1,15 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| 
 | ||||
| <head> | ||||
|     <title>30DaysOfJavaScript:04 Day</title> | ||||
| </head> | ||||
| 
 | ||||
| <body> | ||||
| 
 | ||||
|     <!-- import your scripts here --> | ||||
|     <script src="./scripts/main.js"></script> | ||||
| 
 | ||||
| </body> | ||||
| 
 | ||||
| </html> | ||||
| @ -0,0 +1 @@ | ||||
| // this is your main.js script
 | ||||
| @ -0,0 +1,651 @@ | ||||
| ## Table of Contents | ||||
| 
 | ||||
| ## [<< Day 1](https://github.com/Asabeneh/30DaysOfJavaScript/blob/master/readMe.md) | [Day 3 >>](https://github.com/Asabeneh/30DaysOfJavaScript/blob/master/03_Day/03_booleans_operators_date.md) | ||||
| 
 | ||||
| - [Table of Contents](#table-of-contents) | ||||
| - [<< Day 1 | Day 3 >>](#ltlt-day-1--day-3-gtgt) | ||||
| - [Arrays](#arrays) | ||||
|   - [How to create an empty array](#how-to-create-an-empty-array) | ||||
|   - [How to create an array with values](#how-to-create-an-array-with-values) | ||||
|   - [Creating an array using split](#creating-an-array-using-split) | ||||
|   - [Accessing array items using index](#accessing-array-items-using-index) | ||||
|   - [Modifying array element](#modifying-array-element) | ||||
|   - [Methods to manipulate array](#methods-to-manipulate-array) | ||||
|     - [Array Constructor](#array-constructor) | ||||
|     - [Creating static values with fill](#creating-static-values-with-fill) | ||||
|     - [Concatenating array using concat](#concatenating-array-using-concat) | ||||
|     - [Getting array length](#getting-array-length) | ||||
|     - [Getting index an element in arr array](#getting-index-an-element-in-arr-array) | ||||
|     - [Getting last index of an element in array](#getting-last-index-of-an-element-in-array) | ||||
|     - [Checking array](#checking-array) | ||||
|     - [Converting array to string](#converting-array-to-string) | ||||
|     - [Joining array elements](#joining-array-elements) | ||||
|     - [Slice array elements](#slice-array-elements) | ||||
|     - [Splice method in array](#splice-method-in-array) | ||||
|     - [Adding item to an array using push](#adding-item-to-an-array-using-push) | ||||
|     - [Removing the end element using pop](#removing-the-end-element-using-pop) | ||||
|     - [Removing an element from the beginning](#removing-an-element-from-the-beginning) | ||||
|     - [Add an element from the beginning](#add-an-element-from-the-beginning) | ||||
|     - [Reversing array order](#reversing-array-order) | ||||
|     - [Sorting elements in array](#sorting-elements-in-array) | ||||
| - [Exercise](#exercise) | ||||
| 
 | ||||
| ## Arrays | ||||
| 
 | ||||
| In contrast to variables array can store _multiple values_. Each value in an array has an _index_ and each index has _a reference in a memory address_. Each value can be accessed by using their _indexes_. The index of an array starts from _zero_ and the last element is less by one from the length of the array. | ||||
| 
 | ||||
| Array is a collection of different data types which are ordered and changeable(modifiable). Allows duplicate element and different data types. An array can be empty or it may have different data type values | ||||
| 
 | ||||
| ### How to create an empty array | ||||
| 
 | ||||
| In JavaScript we can create array in different ways. Let us different ways to create an array. | ||||
| 
 | ||||
| - Using Array constructor | ||||
| 
 | ||||
| ```js | ||||
| // syntax | ||||
| const arr = Array() | ||||
| // or | ||||
| // let arr = new Array() | ||||
| console.log(arr) // [] | ||||
| ``` | ||||
| 
 | ||||
| - Using square brackets([]) | ||||
| 
 | ||||
| ```js | ||||
| // syntax | ||||
| // This the most recommended way to create an empty list | ||||
| const arr = [] | ||||
| console.log(arr) | ||||
| ``` | ||||
| 
 | ||||
| ### How to create an array with values | ||||
| 
 | ||||
| Array with initial values. We use _length_ property to find the length of an array. | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [0, 3.14, 9.81, 37, 98.6, 100] // array of numbers | ||||
| const fruits = ['banana', 'orange', 'mango', 'lemon'] // array of strings, fruits | ||||
| const vegetables = ['Tomato', 'Potato', 'Cabbage', 'Onion', 'Carrot'] // array of strings, vegetables | ||||
| const animalProducts = ['milk', 'meat', 'butter', 'yoghurt'] // array of strings, products | ||||
| const webTechs = ['HTML', 'CSS', 'JS', 'React', 'Redux', 'Node', 'MongDB'] // array of web technologies | ||||
| const countries = ['Finland', 'Denmark', 'Sweden', 'Norway', 'Iceland'] // array of strings, countries | ||||
| 
 | ||||
| // Print the array and its length | ||||
| 
 | ||||
| console.log('Numbers:', numbers) | ||||
| console.log('Number of numbers:', numbers.length) | ||||
| 
 | ||||
| console.log('Fruits:', fruits) | ||||
| console.log('Number of fruits:', len(fruits)) | ||||
| 
 | ||||
| console.log('Vegetables:', vegetables) | ||||
| console.log('Number of vegetables:', len(vegetables)) | ||||
| 
 | ||||
| console.log('Animal products:', animalProducts) | ||||
| console.log('Number of animal products:', len(animalProducts)) | ||||
| 
 | ||||
| console.log('Web technologies:', web_techs) | ||||
| console.log('Number of web technologies:', len(webTechs)) | ||||
| 
 | ||||
| console.log('Countries:', countries) | ||||
| console.log('Number of countries:', len(countries)) | ||||
| ``` | ||||
| 
 | ||||
| ```sh | ||||
| Numbers: [0, 3.14, 9.81, 37, 98.6, 100] | ||||
| Number of numbers: 6 | ||||
| Fruits: ['banana', 'orange', 'mango', 'lemon'] | ||||
| Number of fruits: 4 | ||||
| Vegetables: ['Tomato', 'Potato', 'Cabbage', 'Onion', 'Carrot'] | ||||
| Number of vegetables: 5 | ||||
| Animal products: ['milk', 'meat', 'butter', 'yoghurt'] | ||||
| Number of animal products: 4 | ||||
| Web technologies: ['HTML', 'CSS', 'JS', 'React', 'Redux', 'Node', 'MongDB'] | ||||
| Number of web technologies: 7 | ||||
| Countries: ['Finland', 'Estonia', 'Denmark', 'Sweden', 'Norway'] | ||||
| Number of countries: 5 | ||||
| ``` | ||||
| 
 | ||||
| - Array can have items of different data types | ||||
| 
 | ||||
| ```js | ||||
| const arr = [ | ||||
|   'Asabeneh', | ||||
|   250, | ||||
|   True, | ||||
|   { country: 'Finland', city: 'Helsinki' }, | ||||
|   (skills: ['HTML', 'CSS', 'JS', 'React', 'Python']) | ||||
| ] // arr containing different data types | ||||
| console.log(arr) | ||||
| ``` | ||||
| 
 | ||||
| ### Creating an array using split | ||||
| 
 | ||||
| As we have seen in earlier section, we can split a string at different position and we can change to an array. Let us see the examples blow. | ||||
| 
 | ||||
| ```js | ||||
| let js = 'JavaScript' | ||||
| const charsInJavaScript = js.split('') // ["J", "a", "v", "a", "S", "c", "r", "i", "p", "t"] | ||||
| console.log(charsInJavaScript) | ||||
| 
 | ||||
| let companiesString = 'Facebook, Google, Microsoft, Apple, IBM, Oracle, Amazon' | ||||
| const companies = companiesString.split(',') | ||||
| console.log(companies) // ["Facebook", " Google", " Microsoft", " Apple", " IBM", " Oracle", " Amazon"] | ||||
| let text = | ||||
|   'I love teaching and empowering people. I teach HTML, CSS, JS, React, Python.' | ||||
| const words = text.split(' ') | ||||
| console.log(words) | ||||
| // the text has special characters think how you can just get only the words | ||||
| // ["I", "love", "teaching", "and", "empowering", "people.", "I", "teach", "HTML,", "CSS,", "JS,", "React,", "Python"] | ||||
| ``` | ||||
| 
 | ||||
| ### Accessing array items using index | ||||
| 
 | ||||
| We access each element in an array using their index. An array index start from 0. The picture below show clearly the starting of the index. | ||||
| 
 | ||||
|  | ||||
| 
 | ||||
| ```js | ||||
| const fruits = ['banana', 'orange', 'mango', 'lemon'] | ||||
| let firstFruit = fruits[0] // we are accessing the first item using its index | ||||
| console.log(firstFruit) // banana | ||||
| secondFruit = fruits[1] | ||||
| console.log(secondFruit) // orange | ||||
| lastFruit = fruits[3] | ||||
| console.log(lastFruit) // lemon | ||||
| // Last index | ||||
| let lastIndex = len(fruits) - 1 | ||||
| let lastFruit = fruits[lastIndex] | ||||
| ``` | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [0, 3.14, 9.81, 37, 98.6, 100]  // set of numbers | ||||
| 
 | ||||
| console.log(numbers.length)  // => to know the size of the array, which is 6 | ||||
| console.log(numbers)         // -> [0, 3.14, 9.81, 37, 98.6, 100] | ||||
| console.log(numbers[0])      //  -> 0 | ||||
| console.log(numbers[5])      //  -> 100 | ||||
| 
 | ||||
| let lastIndex = numbers.length - 1; | ||||
| console.log(numbers[lastIndex]) -> 100 | ||||
| ``` | ||||
| 
 | ||||
| ```js | ||||
| const webTechs = [ | ||||
|   'HTML', | ||||
|   'CSS', | ||||
|   'JavaScript', | ||||
|   'React', | ||||
|   'Redux', | ||||
|   'Node', | ||||
|   'MongoDB' | ||||
| ] // List of web technologies | ||||
| 
 | ||||
| console.log(webTechs)        // all the array items | ||||
| console.log(webTechs.length) // => to know the size of the array, which is 7 | ||||
| console.log(webTechs[0])     //  -> HTML | ||||
| console.log(webTechs[6])     //  -> MongoDB | ||||
| 
 | ||||
| let lastIndex = webTechs.length - 1 | ||||
| console.log(webTechs[lastIndex]) -> MongoDB | ||||
| ``` | ||||
| 
 | ||||
| ```js | ||||
| const countries = [ | ||||
|   'Albania', | ||||
|   'Bolivia', | ||||
|   'Canada', | ||||
|   'Denmark', | ||||
|   'Ethiopia', | ||||
|   'Finland', | ||||
|   'Germany', | ||||
|   'Hungary', | ||||
|   'Ireland', | ||||
|   'Japan', | ||||
|   'Kenya' | ||||
| ] // List of countries; | ||||
| console.log(countries)      // -> all countries in array | ||||
| console.log(countries[0])   //  -> Albania | ||||
| console.log(countries[10])  //  -> Kenya | ||||
| 
 | ||||
| let lastIndex = countries.length - 1; | ||||
| console.log(countries[lastIndex]) -> // Kenya | ||||
| ``` | ||||
| 
 | ||||
| ```js | ||||
| const shoppingCart = [ | ||||
|   'Milk', | ||||
|   'Mango', | ||||
|   'Tomato', | ||||
|   'Potato', | ||||
|   'Avocado', | ||||
|   'Meat', | ||||
|   'Eggs', | ||||
|   'Sugar' | ||||
| ]; // List of food products | ||||
| console.log(shoppingCart) // -> all shoppingCart in array | ||||
| console.log(shoppingCart[0]) //  -> Milk | ||||
| console.log(shoppingCart[7]) //  -> Sugar | ||||
| 
 | ||||
| let lastIndex = shoppingCart.length - 1; | ||||
| console.log(shoppingCart[lastIndex]) -> // Sugar | ||||
| ``` | ||||
| 
 | ||||
| ### Modifying array element | ||||
| 
 | ||||
| An array is mutable(modifiable). Once an array is created we can modify the contents or the array elements. | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5] | ||||
| numbers[0] = 10      // changing 1 at index 0 to 10 | ||||
| numbers[1] = 20      // changing  2 at index 1 to 20 | ||||
| 
 | ||||
| console.log(numbers) // [10, 20, 3, 4, 5] | ||||
| 
 | ||||
| const countries = [ | ||||
|   'Albania', | ||||
|   'Bolivia', | ||||
|   'Canada', | ||||
|   'Denmark', | ||||
|   'Ethiopia', | ||||
|   'Finland', | ||||
|   'Germany', | ||||
|   'Hungary', | ||||
|   'Ireland', | ||||
|   'Japan', | ||||
|   'Kenya' | ||||
| ]  | ||||
| 
 | ||||
| countries[0] = 'Afghanistan'  // Albania replaced by Afghanistan | ||||
| let lastIndex = countries.length - 1 | ||||
| countries[lastIndex] = 'Korea' | ||||
| 
 | ||||
| console.log(countries) | ||||
| ``` | ||||
| 
 | ||||
| ```sh | ||||
| ["Afghanistan", "Bolivia", "Canada", "Denmark", "Ethiopia", "Finland", "Germany", "Hungary", "Ireland", "Japan", "Korea"] | ||||
| ``` | ||||
| 
 | ||||
| ### Methods to manipulate array | ||||
| 
 | ||||
| There are different methods to manipulate an array. These are some of the available methods to deal with arrays:_Array,length, concat, indexOf, slice, splice, join, toString, includes, lastIndexOf, isArray, fill, push, pop, shift, unshift_ | ||||
| 
 | ||||
| #### Array Constructor | ||||
| 
 | ||||
| Array:To create an array. | ||||
| 
 | ||||
| ```js | ||||
| const arr = Array() // creates an an empty array | ||||
| console.log(arr) | ||||
| 
 | ||||
| const eightEmptyValues = Array(8) // it creates eight empty values | ||||
| console.log(eightEmptyValues) // [empty x 8] | ||||
| ``` | ||||
| 
 | ||||
| #### Creating static values with fill | ||||
| 
 | ||||
| fill: Fill all the array elements with a static value | ||||
| 
 | ||||
| ```js | ||||
| const arr = Array() // creates an an empty array | ||||
| console.log(arr) | ||||
| const eightXvalues = Array(8).fill('X') // it creates eight element values | ||||
| console.log(eightXvalues) // ['X', 'X','X','X','X','X','X','X'] | ||||
| 
 | ||||
| const eight0values = Array(8).fill(0) // it creates eight element values | ||||
| console.log(eight0Values) // [0, 0, 0, 0, 0, 0, 0, 0] | ||||
| 
 | ||||
| const four4values = Array(4).fill(4) // it creates 4 element values | ||||
| console.log(four4Values) // [4, 4, 4, 4, 4, 4, 4, 4] | ||||
| ``` | ||||
| 
 | ||||
| #### Concatenating array using concat | ||||
| 
 | ||||
| concat:To concatenate two arrays. | ||||
| 
 | ||||
| ```js | ||||
| const firstList = [1, 2, 3] | ||||
| const secondList = [4, 5, 6] | ||||
| const thirdList = firstList.concat(secondList) | ||||
| console.log(thirdList) // [1, 2, 3, 4, 5, 6] | ||||
| 
 | ||||
| const fruits = ['banana', 'orange', 'mango', 'lemon'] // array of fruits | ||||
| const vegetables = ['Tomato', 'Potato', 'Cabbage', 'Onion', 'Carrot'] // array of vegetables | ||||
| const fruitsAndVegetables = fruits.concat(vegetables) | ||||
| //["banana", "orange", "mango", "lemon", "Tomato", "Potato", "Cabbage", "Onion", "Carrot"] | ||||
| ``` | ||||
| 
 | ||||
| #### Getting array length | ||||
| 
 | ||||
| Length:To know the size of the array | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5] | ||||
| console.log(numbers.length) // -> 5 | ||||
| ``` | ||||
| 
 | ||||
| #### Getting index an element in arr array | ||||
| 
 | ||||
| indexOf:To check if an item exist in an array. If it exists it returns the index else it returns -1. | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5] | ||||
| 
 | ||||
| console.log(numbers.indexOf(5)) // -> 4 | ||||
| console.log(numbers.indexOf(0)) // -> -1 | ||||
| console.log(numbers.indexOf(1)) // -> 0 | ||||
| console.log(numbers.indexOf(6)) // -> -1 | ||||
| ``` | ||||
| 
 | ||||
| Check an element if it exist in an array | ||||
| 
 | ||||
| - Check items in a list | ||||
|    | ||||
| ```js | ||||
| // let us check if a banana exist in the array | ||||
| 
 | ||||
| const fruits = ['banana', 'orange', 'mango', 'lemon'] | ||||
| let index = fruits.indexOf('banana')  // 0 | ||||
| 
 | ||||
| if(index != -1){ | ||||
|    console.log('This fruit does exist in the array')   | ||||
| } else { | ||||
|     console.log('This fruit does not exist in the array') | ||||
| } | ||||
| // This fruit does exist in the array | ||||
| 
 | ||||
| // we can use also ternary here | ||||
| index != -1 ? console.log('This fruit does exist in the array'): console.log('This fruit does not exist in the array') | ||||
| 
 | ||||
| // let us check if a avocado exist in the array | ||||
| let indexOfAvocado = fruits.indexOf('avocado')  // -1 | ||||
| if(indexOfAvocado!= -1){ | ||||
|    console.log('This fruit does exist in the array')   | ||||
| } else { | ||||
|     console.log('This fruit does not exist in the array') | ||||
| } | ||||
| // This fruit does not exist in the array | ||||
| ``` | ||||
| 
 | ||||
| #### Getting last index of an element in array | ||||
| 
 | ||||
| lastIndexOf:Give the position of the last item in the array. If it exist it returns the index else it returns -1. | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5, 3, 1, 2] | ||||
| console.log(numbers.lastIndexOf(2)) // -> 7 | ||||
| console.log(numbers.lastIndexOf(0)) // -> -1 | ||||
| console.log(numbers.lastIndexOf(1)) // -> 6 | ||||
| console.log(numbers.lastIndexOf(4)) // -> 3 | ||||
| console.log(numbers.lastIndexOf(6)) // -> -1 | ||||
| ``` | ||||
| 
 | ||||
| includes:To check if an item exist in an array. If it exist it returns the true else it returns false. | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5] | ||||
| console.log(numbers.includes(5)) // -> true | ||||
| console.log(numbers.includes(0)) // -> false | ||||
| console.log(numbers.includes(1)) // -> true | ||||
| console.log(numbers.includes(6)) // -> false | ||||
| ``` | ||||
| 
 | ||||
| #### Checking array | ||||
| 
 | ||||
| Array.isArray:To check if the data type is an array | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5] | ||||
| console.log(Array.isArray(numbers)) // -> true | ||||
| const number = 100 | ||||
| console.log(Array.isArray(number)) // -> false | ||||
| ``` | ||||
| 
 | ||||
| #### Converting array to string | ||||
| 
 | ||||
| toString:Converts array to string | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5] | ||||
| console.log(numbers.toString()) // 1,2,3,4,5 | ||||
| const names = ['Asabeneh', 'Mathias', 'Elias', 'Brook'] | ||||
| console.log(names.toString()) // Asabeneh,Mathias,Elias,Brook | ||||
| ``` | ||||
| 
 | ||||
| #### Joining array elements | ||||
| 
 | ||||
| join:To join the elements of the array, the argument passed in the join method will be joined in the array and return as a string. By default it joins with a comma but we can pass different string parameter which can be joined between the items. | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5] | ||||
| console.log(numbers.join()) // 1,2,3,4,5 | ||||
| const names = ['Asabeneh', 'Mathias', 'Elias', 'Brook'] | ||||
| console.log(names.join()) // Asabeneh,Mathias,Elias,Brook | ||||
| console.log(names.join('')) //AsabenehMathiasEliasBrook | ||||
| console.log(names.join(' ')) //Asabeneh Mathias Elias Brook | ||||
| console.log(names.join(', ')) //Asabeneh, Mathias, Elias, Brook | ||||
| console.log(names.join(' # ')) //Asabeneh # Mathias # Elias # Brook | ||||
| ``` | ||||
| 
 | ||||
| #### Slice array elements | ||||
| 
 | ||||
| Slice: To cut out a multiple items in range. It takes two parameters:starting and ending position. It doesn't include the ending position | ||||
| 
 | ||||
| ```js | ||||
|   const numbers = [1,2,3,4,5]; | ||||
|   console.log(numbers.slice() // -> it copies all  item | ||||
|   console.log(numbers.slice(0) // -> it copies all  item | ||||
|   console.log(numbers.indexOf(0, numbers.length)) // it copies all  item | ||||
|   console.log(numbers.slice(1,4)) // -> [2,3,4] // it doesn't include the ending position | ||||
| ``` | ||||
| 
 | ||||
| #### Splice method in array | ||||
| 
 | ||||
| Splice: It takes three parameters:Starting position, number of times to be removed and number items to be added. | ||||
| 
 | ||||
| ```js | ||||
|   const numbers = [1, 2, 3, 4, 5]; | ||||
|   console.log(numbers.splice()                // -> remove all items | ||||
|   console.log(numbers.splice(0,1))            // remove the first item | ||||
|   console.log(numbers.splice(3, 3, 6, 7, 8))  // -> [1,2,6,7,8] //it removes two item and replace three items | ||||
| 
 | ||||
| ``` | ||||
| 
 | ||||
| #### Adding item to an array using push | ||||
| 
 | ||||
| Push: adding item in the end. To add item to the end of an existing array we use the push method | ||||
| 
 | ||||
| ```js | ||||
| // syntax | ||||
| const arr  = ['item1', 'item2','item3'] | ||||
| arr.push('new item') | ||||
| console.log(arr) | ||||
| // ['item1', 'item2','item3','new item'] | ||||
| ``` | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5] | ||||
| numbers.push(6) | ||||
| console.log(numbers) // -> [1,2,3,4,5,6] | ||||
| numbers.pop() // -> remove one item from the end | ||||
| console.log(numbers) // -> [1,2,3,4,5] | ||||
| ``` | ||||
| 
 | ||||
| ```js | ||||
| let fruits = ['banana', 'orange', 'mango', 'lemon'] | ||||
| fruits.push('apple') | ||||
| console.log(fruits)    // ['banana', 'orange', 'mango', 'lemon', 'apple'] | ||||
| fruits.push('lime') | ||||
| console.log(fruits)   // ['banana', 'orange', 'mango', 'lemon', 'apple', 'lime'] | ||||
| ``` | ||||
| 
 | ||||
| #### Removing the end element using pop | ||||
| 
 | ||||
| Pop: Removing item in the end | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5] | ||||
| numbers.pop() // -> remove one item from the end | ||||
| console.log(numbers) // -> [1,2,3,4] | ||||
| ``` | ||||
| 
 | ||||
| #### Removing an element from the beginning | ||||
| 
 | ||||
| shift: Removing one array element in the beginning of the array | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5] | ||||
| numbers.shift() // -> remove one item from the beginning | ||||
| console.log(numbers) // -> [2,3,4,5] | ||||
| ``` | ||||
| 
 | ||||
| #### Add an element from the beginning | ||||
| 
 | ||||
| unshift: Adding array element in the beginning of the array | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5] | ||||
| numbers.unshift(0) // -> remove one item from the beginning | ||||
| console.log(numbers) // -> [0,1,2,3,4,5] | ||||
| ``` | ||||
| 
 | ||||
| #### Reversing array order | ||||
| 
 | ||||
| reverse: reverse the order of an array | ||||
| 
 | ||||
| ```js | ||||
| const numbers = [1, 2, 3, 4, 5] | ||||
| numbers.reverse() // -> reverse array order | ||||
| console.log(numbers) // -> [5, 4, 3, 2, 1] | ||||
| 
 | ||||
| numbers.reverse() | ||||
| console.log(numbers) // [1, 2, 3, 4, 5] | ||||
| ``` | ||||
| 
 | ||||
| #### Sorting elements in array | ||||
| 
 | ||||
| sort: arrange array elements in ascending order. Sort takes a call back function, we wil see how we use sort with call back function in the coming sections. | ||||
| 
 | ||||
| ```js | ||||
| const webTechs = [ | ||||
|   'HTML', | ||||
|   'CSS', | ||||
|   'JavaScript', | ||||
|   'React', | ||||
|   'Redux', | ||||
|   'Node', | ||||
|   'MongoDB' | ||||
| ] | ||||
| 
 | ||||
| webTechs.sort() | ||||
| console.log(webTechs) // ["CSS", "HTML", "JavaScript", "MongoDB", "Node", "React", "Redux"] | ||||
| 
 | ||||
| webTechs.reverse() // after sorting we can reverse it | ||||
| console.log(webTechs) // ["Redux", "React", "Node", "MongoDB", "JavaScript", "HTML", "CSS"] | ||||
| ``` | ||||
| 
 | ||||
| ## Exercise | ||||
| 
 | ||||
| ```js | ||||
| const countries = [ | ||||
|   'Albania', | ||||
|   'Bolivia', | ||||
|   'Canada', | ||||
|   'Denmark', | ||||
|   'Ethiopia', | ||||
|   'Finland', | ||||
|   'Germany', | ||||
|   'Hungary', | ||||
|   'Ireland', | ||||
|   'Japan', | ||||
|   'Kenya' | ||||
| ] | ||||
| 
 | ||||
| const webTechs = [ | ||||
|   'HTML', | ||||
|   'CSS', | ||||
|   'JavaScript', | ||||
|   'React', | ||||
|   'Redux', | ||||
|   'Node', | ||||
|   'MongoDB' | ||||
| ] | ||||
| ``` | ||||
| 
 | ||||
| 1. Declare an _empty_ array; | ||||
| 1. Declare an array with more than 5 number of elements | ||||
| 1. Find the length of your array | ||||
| 1. Get the first item, the middle item and the last item of the array | ||||
| 1. Declare an array called _mixedDataTypes_,put different data types in your array and  find length of the array. You are should size be greater than 5 | ||||
| 1. Declare an array variable name itCompanies and assign initial values Facebook, Google, Microsoft, Apple, IBM, Oracle and Amazon | ||||
| 1. Print the array using _console.log()_ | ||||
| 1. Print the number of companies in the array | ||||
| 1. Print the first company, middle and last company | ||||
| 1. Print out each company | ||||
| 1. Change each company name  to uppercase one by one and print them out | ||||
| 1. Print the array like as a sentence: Facebook, Google, Microsoft, Apple, IBM,Oracle and Amazon are big IT companies. | ||||
| 1. Check if a certain company exists in the itCompanies array. If it exist return the company else return a company is _not found_ | ||||
| 1. Filter out companies which have more than one 'o' without the filter method | ||||
| 1. Sort the array using _sort()_ method | ||||
| 1. Reverse the array using _reverse()_ method | ||||
| 1. Slice out the first 3 companies from the array | ||||
| 1. Slice out the last 3 companies from the array | ||||
| 1. Slice out the middle IT company or companies from the array | ||||
| 1. Remove the first IT company from the array | ||||
| 1. Remove the middle IT company or companies from the array | ||||
| 1. Remove the last IT company from the array | ||||
| 1. Remove all IT companies | ||||
| 1. Create a separate countries.js file and store the countries array in to this file, create a separate file web_techs.js ans store the webTechs array in to this file. Access both file in main.js file | ||||
| 1. First remove all the functions and change the string to array and count the number of words in the array | ||||
| 
 | ||||
|     ```js | ||||
|     let text = | ||||
|     'I love teaching and empowering people. I teach HTML, CSS, JS, React, Python.' | ||||
|     ``` | ||||
| 
 | ||||
|     ```sh | ||||
|     words = ["I", "love", "teaching", "and", "empowering", "people", "I", "teach", "HTML", "CSS", "JS", "React", "Python"] | ||||
|     console.log(words.length) //13 | ||||
|     ``` | ||||
| 
 | ||||
| 1. In the following shopping cart add, remove, edit items | ||||
| 
 | ||||
|     ```js | ||||
|     const shoppingCart = ['Milk', 'Coffee', 'Tea', 'Honey'] | ||||
|     ``` | ||||
| 
 | ||||
|    - add 'Meat' in the beginning of your shopping cart if if it has not be already added | ||||
|    - add sugar at the end of you shopping cart if it has not been already added | ||||
|    - Remove 'Honey' if you are allergic to honey | ||||
|    - modify tea to 'Green Tea' | ||||
| 1. In countries array check if 'Ethiopia' exists in the array if it exists print 'ETHIOPIA'. If it does not exist add to the countries list. | ||||
| 1. In the webTechs array check if Sass exists in the array if it exists print 'Sass is a CSS preprocess'. If it does not exist add Sass to the array. | ||||
| 1. Concatenate the following two variables and store it in a fullStack variable. | ||||
| 
 | ||||
|     ```js | ||||
|     const frontEnd = ['HTML', 'CSS', 'JS', 'React', 'Redux'] | ||||
|     const backEnd = ['Node','Express', 'MongoDB'] | ||||
|     console.log(fullStack) | ||||
|     ``` | ||||
| 
 | ||||
|     ```sh | ||||
|     ["HTML", "CSS", "JS", "React", "Redux", "Node", "Express", "MongoDB"] | ||||
|     ``` | ||||
| 
 | ||||
| 1. The following is a list of 10 students ages: | ||||
| 
 | ||||
|     ```js | ||||
|     const ages = [19, 22, 19, 24, 20, 25, 26, 24, 25, 24] | ||||
|     ``` | ||||
| 
 | ||||
|     - Sort the array and find the min and max age | ||||
|     - Find the min age and the max age | ||||
|     - Find the median age(one middle item or two middle items divided by two) | ||||
|     - Find the average age(all items divided by number of items) | ||||
|     - Find the range of the ages(max minus min) | ||||
|     - Compare the value of (min - average) and (max - average), use *abs()* method | ||||
| 1. Find the middle country(ies) in the [countries list](https://github.com/Asabeneh/30DaysOfJavaScript/tree/master/data/countries.js) | ||||
| 1. Divide the countries list into two equal lists if it is even.  If countries array is not even one more country for the first half. | ||||
|    | ||||
| @ -0,0 +1,195 @@ | ||||
| const countries = [ | ||||
|   'Afghanistan', | ||||
|   'Albania', | ||||
|   'Algeria', | ||||
|   'Andorra', | ||||
|   'Angola', | ||||
|   'Antigua and Barbuda', | ||||
|   'Argentina', | ||||
|   'Armenia', | ||||
|   'Australia', | ||||
|   'Austria', | ||||
|   'Azerbaijan', | ||||
|   'Bahamas', | ||||
|   'Bahrain', | ||||
|   'Bangladesh', | ||||
|   'Barbados', | ||||
|   'Belarus', | ||||
|   'Belgium', | ||||
|   'Belize', | ||||
|   'Benin', | ||||
|   'Bhutan', | ||||
|   'Bolivia', | ||||
|   'Bosnia and Herzegovina', | ||||
|   'Botswana', | ||||
|   'Brazil', | ||||
|   'Brunei', | ||||
|   'Bulgaria', | ||||
|   'Burkina Faso', | ||||
|   'Burundi', | ||||
|   'Cambodia', | ||||
|   'Cameroon', | ||||
|   'Canada', | ||||
|   'Cape Verde', | ||||
|   'Central African Republic', | ||||
|   'Chad', | ||||
|   'Chile', | ||||
|   'China', | ||||
|   'Colombi', | ||||
|   'Comoros', | ||||
|   'Congo (Brazzaville)', | ||||
|   'Congo', | ||||
|   'Costa Rica', | ||||
|   "Cote d'Ivoire", | ||||
|   'Croatia', | ||||
|   'Cuba', | ||||
|   'Cyprus', | ||||
|   'Czech Republic', | ||||
|   'Denmark', | ||||
|   'Djibouti', | ||||
|   'Dominica', | ||||
|   'Dominican Republic', | ||||
|   'East Timor (Timor Timur)', | ||||
|   'Ecuador', | ||||
|   'Egypt', | ||||
|   'El Salvador', | ||||
|   'Equatorial Guinea', | ||||
|   'Eritrea', | ||||
|   'Estonia', | ||||
|   'Ethiopia', | ||||
|   'Fiji', | ||||
|   'Finland', | ||||
|   'France', | ||||
|   'Gabon', | ||||
|   'Gambia, The', | ||||
|   'Georgia', | ||||
|   'Germany', | ||||
|   'Ghana', | ||||
|   'Greece', | ||||
|   'Grenada', | ||||
|   'Guatemala', | ||||
|   'Guinea', | ||||
|   'Guinea-Bissau', | ||||
|   'Guyana', | ||||
|   'Haiti', | ||||
|   'Honduras', | ||||
|   'Hungary', | ||||
|   'Iceland', | ||||
|   'India', | ||||
|   'Indonesia', | ||||
|   'Iran', | ||||
|   'Iraq', | ||||
|   'Ireland', | ||||
|   'Israel', | ||||
|   'Italy', | ||||
|   'Jamaica', | ||||
|   'Japan', | ||||
|   'Jordan', | ||||
|   'Kazakhstan', | ||||
|   'Kenya', | ||||
|   'Kiribati', | ||||
|   'Korea, North', | ||||
|   'Korea, South', | ||||
|   'Kuwait', | ||||
|   'Kyrgyzstan', | ||||
|   'Laos', | ||||
|   'Latvia', | ||||
|   'Lebanon', | ||||
|   'Lesotho', | ||||
|   'Liberia', | ||||
|   'Libya', | ||||
|   'Liechtenstein', | ||||
|   'Lithuania', | ||||
|   'Luxembourg', | ||||
|   'Macedonia', | ||||
|   'Madagascar', | ||||
|   'Malawi', | ||||
|   'Malaysia', | ||||
|   'Maldives', | ||||
|   'Mali', | ||||
|   'Malta', | ||||
|   'Marshall Islands', | ||||
|   'Mauritania', | ||||
|   'Mauritius', | ||||
|   'Mexico', | ||||
|   'Micronesia', | ||||
|   'Moldova', | ||||
|   'Monaco', | ||||
|   'Mongolia', | ||||
|   'Morocco', | ||||
|   'Mozambique', | ||||
|   'Myanmar', | ||||
|   'Namibia', | ||||
|   'Nauru', | ||||
|   'Nepal', | ||||
|   'Netherlands', | ||||
|   'New Zealand', | ||||
|   'Nicaragua', | ||||
|   'Niger', | ||||
|   'Nigeria', | ||||
|   'Norway', | ||||
|   'Oman', | ||||
|   'Pakistan', | ||||
|   'Palau', | ||||
|   'Panama', | ||||
|   'Papua New Guinea', | ||||
|   'Paraguay', | ||||
|   'Peru', | ||||
|   'Philippines', | ||||
|   'Poland', | ||||
|   'Portugal', | ||||
|   'Qatar', | ||||
|   'Romania', | ||||
|   'Russia', | ||||
|   'Rwanda', | ||||
|   'Saint Kitts and Nevis', | ||||
|   'Saint Lucia', | ||||
|   'Saint Vincent', | ||||
|   'Samoa', | ||||
|   'San Marino', | ||||
|   'Sao Tome and Principe', | ||||
|   'Saudi Arabia', | ||||
|   'Senegal', | ||||
|   'Serbia and Montenegro', | ||||
|   'Seychelles', | ||||
|   'Sierra Leone', | ||||
|   'Singapore', | ||||
|   'Slovakia', | ||||
|   'Slovenia', | ||||
|   'Solomon Islands', | ||||
|   'Somalia', | ||||
|   'South Africa', | ||||
|   'Spain', | ||||
|   'Sri Lanka', | ||||
|   'Sudan', | ||||
|   'Suriname', | ||||
|   'Swaziland', | ||||
|   'Sweden', | ||||
|   'Switzerland', | ||||
|   'Syria', | ||||
|   'Taiwan', | ||||
|   'Tajikistan', | ||||
|   'Tanzania', | ||||
|   'Thailand', | ||||
|   'Togo', | ||||
|   'Tonga', | ||||
|   'Trinidad and Tobago', | ||||
|   'Tunisia', | ||||
|   'Turkey', | ||||
|   'Turkmenistan', | ||||
|   'Tuvalu', | ||||
|   'Uganda', | ||||
|   'Ukraine', | ||||
|   'United Arab Emirates', | ||||
|   'United Kingdom', | ||||
|   'United States', | ||||
|   'Uruguay', | ||||
|   'Uzbekistan', | ||||
|   'Vanuatu', | ||||
|   'Vatican City', | ||||
|   'Venezuela', | ||||
|   'Vietnam', | ||||
|   'Yemen', | ||||
|   'Zambia', | ||||
|   'Zimbabwe' | ||||
| ] | ||||
| @ -0,0 +1,15 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| 
 | ||||
| <head> | ||||
|     <title>30DaysOfJavaScript:05 Day </title> | ||||
| </head> | ||||
| 
 | ||||
| <body> | ||||
|      | ||||
|     <script src="./data/countries.js"></script> | ||||
|     <script src="./scripts/main.js"></script> | ||||
| 
 | ||||
| </body> | ||||
| 
 | ||||
| </html> | ||||
| @ -0,0 +1,2 @@ | ||||
| console.log(countries) | ||||
| alert('Open the console and check if the countries has been loaded') | ||||
| @ -0,0 +1,195 @@ | ||||
| const countries = [ | ||||
|   'Afghanistan', | ||||
|   'Albania', | ||||
|   'Algeria', | ||||
|   'Andorra', | ||||
|   'Angola', | ||||
|   'Antigua and Barbuda', | ||||
|   'Argentina', | ||||
|   'Armenia', | ||||
|   'Australia', | ||||
|   'Austria', | ||||
|   'Azerbaijan', | ||||
|   'Bahamas', | ||||
|   'Bahrain', | ||||
|   'Bangladesh', | ||||
|   'Barbados', | ||||
|   'Belarus', | ||||
|   'Belgium', | ||||
|   'Belize', | ||||
|   'Benin', | ||||
|   'Bhutan', | ||||
|   'Bolivia', | ||||
|   'Bosnia and Herzegovina', | ||||
|   'Botswana', | ||||
|   'Brazil', | ||||
|   'Brunei', | ||||
|   'Bulgaria', | ||||
|   'Burkina Faso', | ||||
|   'Burundi', | ||||
|   'Cambodia', | ||||
|   'Cameroon', | ||||
|   'Canada', | ||||
|   'Cape Verde', | ||||
|   'Central African Republic', | ||||
|   'Chad', | ||||
|   'Chile', | ||||
|   'China', | ||||
|   'Colombi', | ||||
|   'Comoros', | ||||
|   'Congo (Brazzaville)', | ||||
|   'Congo', | ||||
|   'Costa Rica', | ||||
|   "Cote d'Ivoire", | ||||
|   'Croatia', | ||||
|   'Cuba', | ||||
|   'Cyprus', | ||||
|   'Czech Republic', | ||||
|   'Denmark', | ||||
|   'Djibouti', | ||||
|   'Dominica', | ||||
|   'Dominican Republic', | ||||
|   'East Timor (Timor Timur)', | ||||
|   'Ecuador', | ||||
|   'Egypt', | ||||
|   'El Salvador', | ||||
|   'Equatorial Guinea', | ||||
|   'Eritrea', | ||||
|   'Estonia', | ||||
|   'Ethiopia', | ||||
|   'Fiji', | ||||
|   'Finland', | ||||
|   'France', | ||||
|   'Gabon', | ||||
|   'Gambia, The', | ||||
|   'Georgia', | ||||
|   'Germany', | ||||
|   'Ghana', | ||||
|   'Greece', | ||||
|   'Grenada', | ||||
|   'Guatemala', | ||||
|   'Guinea', | ||||
|   'Guinea-Bissau', | ||||
|   'Guyana', | ||||
|   'Haiti', | ||||
|   'Honduras', | ||||
|   'Hungary', | ||||
|   'Iceland', | ||||
|   'India', | ||||
|   'Indonesia', | ||||
|   'Iran', | ||||
|   'Iraq', | ||||
|   'Ireland', | ||||
|   'Israel', | ||||
|   'Italy', | ||||
|   'Jamaica', | ||||
|   'Japan', | ||||
|   'Jordan', | ||||
|   'Kazakhstan', | ||||
|   'Kenya', | ||||
|   'Kiribati', | ||||
|   'Korea, North', | ||||
|   'Korea, South', | ||||
|   'Kuwait', | ||||
|   'Kyrgyzstan', | ||||
|   'Laos', | ||||
|   'Latvia', | ||||
|   'Lebanon', | ||||
|   'Lesotho', | ||||
|   'Liberia', | ||||
|   'Libya', | ||||
|   'Liechtenstein', | ||||
|   'Lithuania', | ||||
|   'Luxembourg', | ||||
|   'Macedonia', | ||||
|   'Madagascar', | ||||
|   'Malawi', | ||||
|   'Malaysia', | ||||
|   'Maldives', | ||||
|   'Mali', | ||||
|   'Malta', | ||||
|   'Marshall Islands', | ||||
|   'Mauritania', | ||||
|   'Mauritius', | ||||
|   'Mexico', | ||||
|   'Micronesia', | ||||
|   'Moldova', | ||||
|   'Monaco', | ||||
|   'Mongolia', | ||||
|   'Morocco', | ||||
|   'Mozambique', | ||||
|   'Myanmar', | ||||
|   'Namibia', | ||||
|   'Nauru', | ||||
|   'Nepal', | ||||
|   'Netherlands', | ||||
|   'New Zealand', | ||||
|   'Nicaragua', | ||||
|   'Niger', | ||||
|   'Nigeria', | ||||
|   'Norway', | ||||
|   'Oman', | ||||
|   'Pakistan', | ||||
|   'Palau', | ||||
|   'Panama', | ||||
|   'Papua New Guinea', | ||||
|   'Paraguay', | ||||
|   'Peru', | ||||
|   'Philippines', | ||||
|   'Poland', | ||||
|   'Portugal', | ||||
|   'Qatar', | ||||
|   'Romania', | ||||
|   'Russia', | ||||
|   'Rwanda', | ||||
|   'Saint Kitts and Nevis', | ||||
|   'Saint Lucia', | ||||
|   'Saint Vincent', | ||||
|   'Samoa', | ||||
|   'San Marino', | ||||
|   'Sao Tome and Principe', | ||||
|   'Saudi Arabia', | ||||
|   'Senegal', | ||||
|   'Serbia and Montenegro', | ||||
|   'Seychelles', | ||||
|   'Sierra Leone', | ||||
|   'Singapore', | ||||
|   'Slovakia', | ||||
|   'Slovenia', | ||||
|   'Solomon Islands', | ||||
|   'Somalia', | ||||
|   'South Africa', | ||||
|   'Spain', | ||||
|   'Sri Lanka', | ||||
|   'Sudan', | ||||
|   'Suriname', | ||||
|   'Swaziland', | ||||
|   'Sweden', | ||||
|   'Switzerland', | ||||
|   'Syria', | ||||
|   'Taiwan', | ||||
|   'Tajikistan', | ||||
|   'Tanzania', | ||||
|   'Thailand', | ||||
|   'Togo', | ||||
|   'Tonga', | ||||
|   'Trinidad and Tobago', | ||||
|   'Tunisia', | ||||
|   'Turkey', | ||||
|   'Turkmenistan', | ||||
|   'Tuvalu', | ||||
|   'Uganda', | ||||
|   'Ukraine', | ||||
|   'United Arab Emirates', | ||||
|   'United Kingdom', | ||||
|   'United States', | ||||
|   'Uruguay', | ||||
|   'Uzbekistan', | ||||
|   'Vanuatu', | ||||
|   'Vatican City', | ||||
|   'Venezuela', | ||||
|   'Vietnam', | ||||
|   'Yemen', | ||||
|   'Zambia', | ||||
|   'Zimbabwe' | ||||
| ] | ||||
| After Width: | Height: | Size: 12 KiB | 
					Loading…
					
					
				
		Reference in new issue