| @ -0,0 +1,475 @@ | |||||||
|  | <div align="center"> | ||||||
|  |   <h1> 30 Days Of JavaScript</h1> | ||||||
|  |   <a class="header-badge" target="_blank" href="https://www.linkedin.com/in/asabeneh/"> | ||||||
|  |   <img src="https://img.shields.io/badge/style--5eba00.svg?label=LinkedIn&logo=linkedin&style=social"> | ||||||
|  |   </a> | ||||||
|  |   <a class="header-badge" target="_blank" href="https://twitter.com/Asabeneh"> | ||||||
|  |   <img alt="Twitter Follow" src="https://img.shields.io/twitter/follow/asabeneh?style=social"> | ||||||
|  |   </a> | ||||||
|  | 
 | ||||||
|  | <sub>Author: | ||||||
|  | <a href="https://www.linkedin.com/in/asabeneh/" target="_blank">Asabeneh Yetayeh</a><br> | ||||||
|  | <small> January, 2020</small> | ||||||
|  | </sub> | ||||||
|  | 
 | ||||||
|  | </div> | ||||||
|  | 
 | ||||||
|  | [<< Day 15](https://github.com/Asabeneh/30DaysOfJavaScript/blob/master/15_Day/15_day_classes.md) | [Day 17>>](#) | ||||||
|  | 
 | ||||||
|  |  | ||||||
|  | 
 | ||||||
|  | - [Day 16](#day-16) | ||||||
|  |   - [JSON](#json) | ||||||
|  |     - [Converting JSON to JavaScript Object](#converting-json-to-javascript-object) | ||||||
|  |       - [JSON.parse()](#jsonparse) | ||||||
|  |     - [Using a reviver function with JSON.parse()](#using-a-reviver-function-with-jsonparse) | ||||||
|  |     - [Converting Object to JSON](#converting-object-to-json) | ||||||
|  |     - [Using a Filter Array with JSON.stringify](#using-a-filter-array-with-jsonstringify) | ||||||
|  |   - [Exercises](#exercises) | ||||||
|  |     - [Exercises Level 1](#exercises-level-1) | ||||||
|  |     - [Exercises Level 2](#exercises-level-2) | ||||||
|  |     - [Exercises Level 3](#exercises-level-3) | ||||||
|  | 
 | ||||||
|  | # Day 16 | ||||||
|  | 
 | ||||||
|  | ## JSON | ||||||
|  | 
 | ||||||
|  | JSON stands for JavaScript Object Notation. The JSON syntax is derived from JavaScript object notation syntax, but the JSON format is text or string only. JSON is a light weight data format for storing and transporting. JSON is mostly used when data is sent from a server to a client. JSON is an easier-to-use alternative to XML. | ||||||
|  | 
 | ||||||
|  | **Example:** | ||||||
|  | 
 | ||||||
|  | ```js | ||||||
|  | { | ||||||
|  | "users":[ | ||||||
|  |   { | ||||||
|  |     "firstName":"Asabeneh", | ||||||
|  |     "lastName":"Yetayeh", | ||||||
|  |     "age":250, | ||||||
|  |     "email":"asab@asb.com" | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |     "firstName":"Alex", | ||||||
|  |     "lastName":"James", | ||||||
|  |     "age":25, | ||||||
|  |     "email":"alex@alex.com" | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |   "firstName":"Lidiya", | ||||||
|  |   "lastName":"Tekle", | ||||||
|  |   "age":28, | ||||||
|  |   "email":"lidiya@lidiya.com" | ||||||
|  |   } | ||||||
|  | ] | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | The above JSON example is not much different for a normal object. Then, what is the difference ? The difference is the key of a JSON object should be with double quotes or it should be a string. JavaScript Object and JSON are very similar that we can change JSON to Object and Object to JSON. | ||||||
|  | 
 | ||||||
|  | Let us see the above example in more detail, it starts with a curly bracket. Inside the curly bracket, there is "users" key which has a value array. Inside the array we have different objects and each objects has keys, each keys has to have double quotes. For instance, we use "firstNaMe" instead of just firstName, however in object we use keys without double quotes. This is the major difference between an object and a JSON. Let's see more examples about JSON. | ||||||
|  | 
 | ||||||
|  | **Example:** | ||||||
|  | 
 | ||||||
|  | ```js | ||||||
|  | { | ||||||
|  |     "Alex": { | ||||||
|  |         "email": "alex@alex.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript" | ||||||
|  |         ], | ||||||
|  |         "age": 20, | ||||||
|  |         "isLoggedIn": false, | ||||||
|  |         "points": 30 | ||||||
|  |     }, | ||||||
|  |     "Asab": { | ||||||
|  |         "email": "asab@asab.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript", | ||||||
|  |             "Redux", | ||||||
|  |             "MongoDB", | ||||||
|  |             "Express", | ||||||
|  |             "React", | ||||||
|  |             "Node" | ||||||
|  |         ], | ||||||
|  |         "age": 25, | ||||||
|  |         "isLoggedIn": false, | ||||||
|  |         "points": 50 | ||||||
|  |     }, | ||||||
|  |     "Brook": { | ||||||
|  |         "email": "daniel@daniel.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript", | ||||||
|  |             "React", | ||||||
|  |             "Redux" | ||||||
|  |         ], | ||||||
|  |         "age": 30, | ||||||
|  |         "isLoggedIn": true, | ||||||
|  |         "points": 50 | ||||||
|  |     }, | ||||||
|  |     "Daniel": { | ||||||
|  |         "email": "daniel@alex.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript", | ||||||
|  |             "Python" | ||||||
|  |         ], | ||||||
|  |         "age": 20, | ||||||
|  |         "isLoggedIn": false, | ||||||
|  |         "points": 40 | ||||||
|  |     }, | ||||||
|  |     "John": { | ||||||
|  |         "email": "john@john.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript", | ||||||
|  |             "React", | ||||||
|  |             "Redux", | ||||||
|  |             "Node.js" | ||||||
|  |         ], | ||||||
|  |         "age": 20, | ||||||
|  |         "isLoggedIn": true, | ||||||
|  |         "points": 50 | ||||||
|  |     }, | ||||||
|  |     "Thomas": { | ||||||
|  |         "email": "thomas@thomas.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript", | ||||||
|  |             "React" | ||||||
|  |         ], | ||||||
|  |         "age": 20, | ||||||
|  |         "isLoggedIn": false, | ||||||
|  |         "points": 40 | ||||||
|  |     }, | ||||||
|  |     "Paul": { | ||||||
|  |         "email": "paul@paul.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript", | ||||||
|  |             "MongoDB", | ||||||
|  |             "Express", | ||||||
|  |             "React", | ||||||
|  |             "Node" | ||||||
|  |         ], | ||||||
|  |         "age": 20, | ||||||
|  |         "isLoggedIn": false, | ||||||
|  |         "points": 40 | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | ### Converting JSON to JavaScript Object | ||||||
|  | 
 | ||||||
|  | Mostly we fetch JSON data from HTTP response or from a file, but we can store the JSON as a string and we can change to Object for sake of demonstration. In JavaScript the keyword _JSON_ has _parse()_ and _stringify()_ methods. When we want to change the JSON to an object we parse the JSON using _JSON.parse()_. When we want to change the object to JSON we use _JSON.stringify()_. | ||||||
|  | 
 | ||||||
|  | #### JSON.parse() | ||||||
|  | 
 | ||||||
|  | ```js | ||||||
|  | JSON.parse(json[, reviver]) | ||||||
|  | // json or text , the data | ||||||
|  | // reviver is an optional callback function | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | ```js | ||||||
|  | const usersText = `{ | ||||||
|  | "users":[ | ||||||
|  |   { | ||||||
|  |     "firstName":"Asabeneh", | ||||||
|  |     "lastName":"Yetayeh", | ||||||
|  |     "age":250, | ||||||
|  |     "email":"asab@asb.com" | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |     "firstName":"Alex", | ||||||
|  |     "lastName":"James", | ||||||
|  |     "age":25, | ||||||
|  |     "email":"alex@alex.com" | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |   "firstName":"Lidiya", | ||||||
|  |   "lastName":"Tekle", | ||||||
|  |   "age":28, | ||||||
|  |   "email":"lidiya@lidiya.com" | ||||||
|  |   } | ||||||
|  | ] | ||||||
|  | }` | ||||||
|  | 
 | ||||||
|  | const usersObj = JSON.parse(usersText, undefined, 4) | ||||||
|  | console.log(usersObj) | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | ### Using a reviver function with JSON.parse() | ||||||
|  | 
 | ||||||
|  | To use the reviver function as a formatter, we put the keys we want to format first name and last name value. Let us say, we are interested to format the firstName and lastName of the JSON data . | ||||||
|  | 
 | ||||||
|  | ```js | ||||||
|  | const usersText = `{ | ||||||
|  | "users":[ | ||||||
|  |   { | ||||||
|  |     "firstName":"Asabeneh", | ||||||
|  |     "lastName":"Yetayeh", | ||||||
|  |     "age":250, | ||||||
|  |     "email":"asab@asb.com" | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |     "firstName":"Alex", | ||||||
|  |     "lastName":"James", | ||||||
|  |     "age":25, | ||||||
|  |     "email":"alex@alex.com" | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |   "firstName":"Lidiya", | ||||||
|  |   "lastName":"Tekle", | ||||||
|  |   "age":28, | ||||||
|  |   "email":"lidiya@lidiya.com" | ||||||
|  |   } | ||||||
|  | ] | ||||||
|  | }` | ||||||
|  | 
 | ||||||
|  | const usersObj = JSON.parse(usersText, (key, value) => { | ||||||
|  |   let newValue = | ||||||
|  |     typeof value == 'string' && key != 'email' ? value.toUpperCase() : value | ||||||
|  |   return newValue | ||||||
|  | }) | ||||||
|  | console.log(usersObj) | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | The _JSON.parse()_ is very handy to use. You do not have to pass optional parameter, you can just use it with the required parameter and you will achieve quite a lot. | ||||||
|  | 
 | ||||||
|  | ### Converting Object to JSON | ||||||
|  | 
 | ||||||
|  | When we want to change the object to JSON we use _JSON.stringify()_. The stringify method takes one required parameter and two optional parameters. The replacer is used as filter and the space is an indentations. If we do not want to filter out any of the keys from the object we can just pass undefined. | ||||||
|  | 
 | ||||||
|  | ```js | ||||||
|  | JSON.stringify(obj, replacer, space) | ||||||
|  | // json or text , the data | ||||||
|  | // reviver is an optional callback function | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | Let us convert the following object to a string. First let use keep all the keys and also let us have 4 space indentation. | ||||||
|  | 
 | ||||||
|  | ```js | ||||||
|  | const users = { | ||||||
|  |   Alex: { | ||||||
|  |     email: 'alex@alex.com', | ||||||
|  |     skills: ['HTML', 'CSS', 'JavaScript'], | ||||||
|  |     age: 20, | ||||||
|  |     isLoggedIn: false, | ||||||
|  |     points: 30 | ||||||
|  |   }, | ||||||
|  |   Asab: { | ||||||
|  |     email: 'asab@asab.com', | ||||||
|  |     skills: [ | ||||||
|  |       'HTML', | ||||||
|  |       'CSS', | ||||||
|  |       'JavaScript', | ||||||
|  |       'Redux', | ||||||
|  |       'MongoDB', | ||||||
|  |       'Express', | ||||||
|  |       'React', | ||||||
|  |       'Node' | ||||||
|  |     ], | ||||||
|  |     age: 25, | ||||||
|  |     isLoggedIn: false, | ||||||
|  |     points: 50 | ||||||
|  |   }, | ||||||
|  |   Brook: { | ||||||
|  |     email: 'daniel@daniel.com', | ||||||
|  |     skills: ['HTML', 'CSS', 'JavaScript', 'React', 'Redux'], | ||||||
|  |     age: 30, | ||||||
|  |     isLoggedIn: true, | ||||||
|  |     points: 50 | ||||||
|  |   }, | ||||||
|  |   Daniel: { | ||||||
|  |     email: 'daniel@alex.com', | ||||||
|  |     skills: ['HTML', 'CSS', 'JavaScript', 'Python'], | ||||||
|  |     age: 20, | ||||||
|  |     isLoggedIn: false, | ||||||
|  |     points: 40 | ||||||
|  |   }, | ||||||
|  |   John: { | ||||||
|  |     email: 'john@john.com', | ||||||
|  |     skills: ['HTML', 'CSS', 'JavaScript', 'React', 'Redux', 'Node.js'], | ||||||
|  |     age: 20, | ||||||
|  |     isLoggedIn: true, | ||||||
|  |     points: 50 | ||||||
|  |   }, | ||||||
|  |   Thomas: { | ||||||
|  |     email: 'thomas@thomas.com', | ||||||
|  |     skills: ['HTML', 'CSS', 'JavaScript', 'React'], | ||||||
|  |     age: 20, | ||||||
|  |     isLoggedIn: false, | ||||||
|  |     points: 40 | ||||||
|  |   }, | ||||||
|  |   Paul: { | ||||||
|  |     email: 'paul@paul.com', | ||||||
|  |     skills: [ | ||||||
|  |       'HTML', | ||||||
|  |       'CSS', | ||||||
|  |       'JavaScript', | ||||||
|  |       'MongoDB', | ||||||
|  |       'Express', | ||||||
|  |       'React', | ||||||
|  |       'Node' | ||||||
|  |     ], | ||||||
|  |     age: 20, | ||||||
|  |     isLoggedIn: false, | ||||||
|  |     points: 40 | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const text = JSON.stringify(users, undefined, 4) | ||||||
|  | console.log(text) // text means JSON- because json is a string form of an object. | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | ```sh | ||||||
|  | { | ||||||
|  |     "Alex": { | ||||||
|  |         "email": "alex@alex.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript" | ||||||
|  |         ], | ||||||
|  |         "age": 20, | ||||||
|  |         "isLoggedIn": false, | ||||||
|  |         "points": 30 | ||||||
|  |     }, | ||||||
|  |     "Asab": { | ||||||
|  |         "email": "asab@asab.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript", | ||||||
|  |             "Redux", | ||||||
|  |             "MongoDB", | ||||||
|  |             "Express", | ||||||
|  |             "React", | ||||||
|  |             "Node" | ||||||
|  |         ], | ||||||
|  |         "age": 25, | ||||||
|  |         "isLoggedIn": false, | ||||||
|  |         "points": 50 | ||||||
|  |     }, | ||||||
|  |     "Brook": { | ||||||
|  |         "email": "daniel@daniel.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript", | ||||||
|  |             "React", | ||||||
|  |             "Redux" | ||||||
|  |         ], | ||||||
|  |         "age": 30, | ||||||
|  |         "isLoggedIn": true, | ||||||
|  |         "points": 50 | ||||||
|  |     }, | ||||||
|  |     "Daniel": { | ||||||
|  |         "email": "daniel@alex.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript", | ||||||
|  |             "Python" | ||||||
|  |         ], | ||||||
|  |         "age": 20, | ||||||
|  |         "isLoggedIn": false, | ||||||
|  |         "points": 40 | ||||||
|  |     }, | ||||||
|  |     "John": { | ||||||
|  |         "email": "john@john.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript", | ||||||
|  |             "React", | ||||||
|  |             "Redux", | ||||||
|  |             "Node.js" | ||||||
|  |         ], | ||||||
|  |         "age": 20, | ||||||
|  |         "isLoggedIn": true, | ||||||
|  |         "points": 50 | ||||||
|  |     }, | ||||||
|  |     "Thomas": { | ||||||
|  |         "email": "thomas@thomas.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript", | ||||||
|  |             "React" | ||||||
|  |         ], | ||||||
|  |         "age": 20, | ||||||
|  |         "isLoggedIn": false, | ||||||
|  |         "points": 40 | ||||||
|  |     }, | ||||||
|  |     "Paul": { | ||||||
|  |         "email": "paul@paul.com", | ||||||
|  |         "skills": [ | ||||||
|  |             "HTML", | ||||||
|  |             "CSS", | ||||||
|  |             "JavaScript", | ||||||
|  |             "MongoDB", | ||||||
|  |             "Express", | ||||||
|  |             "React", | ||||||
|  |             "Node" | ||||||
|  |         ], | ||||||
|  |         "age": 20, | ||||||
|  |         "isLoggedIn": false, | ||||||
|  |         "points": 40 | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | ### Using a Filter Array with JSON.stringify | ||||||
|  | 
 | ||||||
|  | Now, lets use the replacer as a filter. The user object has long list of keys but we are interested only in few of them. We put the keys we want to keep in array as show in the example and use it the place of the replacer. | ||||||
|  | 
 | ||||||
|  | ```js | ||||||
|  | const user = { | ||||||
|  |   firstName: 'Asabeneh', | ||||||
|  |   lastName: 'Yetayeh', | ||||||
|  |   country: 'Finland', | ||||||
|  |   city: 'Helsinki', | ||||||
|  |   email: 'alex@alex.com', | ||||||
|  |   skills: ['HTML', 'CSS', 'JavaScript', 'React', 'Pyhton'], | ||||||
|  |   age: 250, | ||||||
|  |   isLoggedIn: false, | ||||||
|  |   points: 30 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const text = JSON.stringify(user,['firstName', 'lastName', 'country', 'city', 'age'],4) | ||||||
|  | console.log(text) | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | ```sh | ||||||
|  | { | ||||||
|  |     "firstName": "Asabeneh", | ||||||
|  |     "lastName": "Yetayeh", | ||||||
|  |     "country": "Finland", | ||||||
|  |     "city": "Helsinki", | ||||||
|  |     "age": 250 | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | 🌕 You are extraordinary Now, you knew a light-weight data format which you may use to store data or to send it an HTTP server. You are 16 steps a head to your way to greatness. Now do some exercises for your brain and for your muscle. | ||||||
|  | 
 | ||||||
|  | ## Exercises | ||||||
|  | 
 | ||||||
|  | ### Exercises Level 1 | ||||||
|  | 
 | ||||||
|  | ### Exercises Level 2 | ||||||
|  | 
 | ||||||
|  | ### Exercises Level 3 | ||||||
|  | 
 | ||||||
|  | 🎉 CONGRATULATIONS ! 🎉 | ||||||
|  | 
 | ||||||
|  | [<< Day 15](https://github.com/Asabeneh/30DaysOfJavaScript/blob/master/15_Day/15_day_classes.md) | [Day 17>>](#) | ||||||
| @ -0,0 +1,17 @@ | |||||||
|  | <!DOCTYPE html> | ||||||
|  | <html> | ||||||
|  | 
 | ||||||
|  | <head> | ||||||
|  |     <title>30DaysOfJavaScript:16 Day </title> | ||||||
|  | </head> | ||||||
|  | 
 | ||||||
|  | <body> | ||||||
|  |     <h1>30DaysOfJavaScript:16 Day</h1> | ||||||
|  |     <h2>JSON</h2> | ||||||
|  | 
 | ||||||
|  |     <script src="./data/countries_data.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') | ||||||
| Before Width: | Height: | Size: 75 KiB After Width: | Height: | Size: 75 KiB | 
| Before Width: | Height: | Size: 74 KiB After Width: | Height: | Size: 74 KiB | 
| Before Width: | Height: | Size: 75 KiB After Width: | Height: | Size: 75 KiB | 
| Before Width: | Height: | Size: 75 KiB After Width: | Height: | Size: 75 KiB | 
| Before Width: | Height: | Size: 75 KiB After Width: | Height: | Size: 75 KiB | 
| @ -0,0 +1,109 @@ | |||||||
|  | <!DOCTYPE html> | ||||||
|  | <html> | ||||||
|  | 
 | ||||||
|  | <head> | ||||||
|  |     <title>Document Object Model:30 Days Of JavaScript</title> | ||||||
|  |     <link href="https://fonts.googleapis.com/css?family=Aldrich|Roboto|Lato|Raleway | ||||||
|  | :300,400,500&display=swap" rel="stylesheet"> | ||||||
|  |     <style> | ||||||
|  |         * { | ||||||
|  |             box-sizing: border-box; | ||||||
|  |             padding: 0; | ||||||
|  |             margin: 0; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         body { | ||||||
|  |             text-align: center; | ||||||
|  |             margin-top: 50px; | ||||||
|  |             font-family: 'Lato', sans-serif; | ||||||
|  | 
 | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         h1 { | ||||||
|  |             font-size: 36px; | ||||||
|  |             margin: 50px auto; | ||||||
|  |             background: #fbe324; | ||||||
|  |             width: 650px; | ||||||
|  |             padding: 15px; | ||||||
|  |             color: #444; | ||||||
|  |             font-weight: lighter; | ||||||
|  | 
 | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         input { | ||||||
|  |             width: 250px; | ||||||
|  |             height: 45px; | ||||||
|  |             text-indent: 10px; | ||||||
|  |             font-size: 18px; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         input:focus { | ||||||
|  |             border: 1px solid #fbe324; | ||||||
|  |             outline: 1px solid #fbe324; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         input::placeholder { | ||||||
|  |             color: rgb(195, 190, 190); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         button { | ||||||
|  |             width: 150px; | ||||||
|  |             height: 45px; | ||||||
|  |             border: none; | ||||||
|  |             background: #fbe324; | ||||||
|  |             color: #444; | ||||||
|  |             font-size: 18px; | ||||||
|  |             font-family: 'Lato', sans-serif; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         button:focus{ | ||||||
|  |             border: 1px solid #fbe324; | ||||||
|  |             outline: 1px solid #fbe324; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         p { | ||||||
|  |             margin: 15px auto; | ||||||
|  |             background: #fbe324; | ||||||
|  |             width: 650px; | ||||||
|  |             padding: 5px; | ||||||
|  |             font-size: 28px; | ||||||
|  |             font-family: 'Raleway', sans-serif; | ||||||
|  | 
 | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         span { | ||||||
|  |             display: inline-block; | ||||||
|  |             width: 80px; | ||||||
|  |             height: 80px; | ||||||
|  |             padding: 5px; | ||||||
|  |             border-radius: 50%; | ||||||
|  |             background: rgb(246, 192, 91); | ||||||
|  |             line-height: 70px; | ||||||
|  |         } | ||||||
|  |     </style> | ||||||
|  | </head> | ||||||
|  | 
 | ||||||
|  | <body> | ||||||
|  | 
 | ||||||
|  |     <h1>Body Mass Index Calculator</h1> | ||||||
|  | 
 | ||||||
|  |     <input type="text" id="mass" placeholder="Mass in Kilogram" /> | ||||||
|  |     <input type="text" id="height" placeholder="Height in meters" /> | ||||||
|  |     <button>Calculate BMI</button> | ||||||
|  | 
 | ||||||
|  |     <script> | ||||||
|  |         const mass = document.querySelector('#mass') | ||||||
|  |         const height = document.querySelector('#height') | ||||||
|  |         const button = document.querySelector('button') | ||||||
|  |         const bmiResult = document.createElement('p') | ||||||
|  |         let bmi | ||||||
|  |         button.addEventListener('click', () => { | ||||||
|  |             bmi = mass.value / height.value ** 2 | ||||||
|  |             bmiResult.innerHTML = `<span>${bmi.toFixed(2)}</span>` | ||||||
|  |             document.body.appendChild(bmiResult) | ||||||
|  | 
 | ||||||
|  |         }) | ||||||
|  |     </script> | ||||||
|  | </body> | ||||||
|  | 
 | ||||||
|  | </html> | ||||||