forked from Dezenix/frontend-html-css-js
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
48 lines (45 loc) · 1.45 KB
/
script.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
let getFactBtn = document.getElementById("get-fact-btn");
let ranFactBtn = document.getElementById("ran-fact-btn");
let fact = document.querySelector(".fact");
let url = "http://numbersapi.com/";
let fetchFact = (num) => {
let finalUrl = url + num;
fetch(finalUrl)
.then((resp) => resp.text())
.then((data) => {
fact.style.display = "block";
fact.innerHTML = `<h2>${num}</h2>
<p>${data}</p>`;
document.querySelector(".container").append(fact);
});
};
let getFact = () => {
let num = document.getElementById("num").value;
//Check if input number is not empty
//If not empty
if (num) {
//Check if number lies between 0 and 300
//if Yes fetch the fact
if (num >= 0 && num <= 300) {
fetchFact(num);
}
//If number is less than 0 or greater than 300 display error message.
else {
fact.style.display = "block";
fact.innerHTML = `<p class="msg"> Please enter a number between 0 to 300.</p>`;
}
}
//If input number is empty display error message
else {
fact.style.display = "block";
fact.innerHTML = `<p class="msg">The input field cannot be empty</p>`;
}
};
let getRandomFact = () => {
//Random number between 0 to 300
let num = Math.floor(Math.random() * 301);
fetchFact(num);
};
getFactBtn.addEventListener("click", getFact);
ranFactBtn.addEventListener("click", getRandomFact);
window.addEventListener("load", getRandomFact);