-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathApp.js
61 lines (48 loc) · 1.37 KB
/
App.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
49
50
51
52
53
54
55
56
57
58
59
60
61
import React, { useState } from "react";
//Result screen imported
import Result from "./components/Result";
//keypad component imported
import Keypad from "./components/Keypad";
import "./app.css";
export default function App() {
//mathmatical operations of numbers are done in values state
const [values, setvalues] = useState("");
//calculate function will evaluates the results of mathmatical operation
//eval inbuilt function performs the necessary mathmatical operation
function calculate() {
try {
setvalues(eval(values));
} catch (error) {
setvalues("error ,press clear for new calculation");
}
}
//clear function will do the erase all data and can helps in doing new mathmatical operation
function clear() {
setvalues(" ");
}
//back function will perform the backspace operation
function back() {
try {
setvalues(values.slice(0, -1));
} catch (error) {
setvalues("press clear for new calculation");
}
}
return (
<div>
<div className="calculator-body">
<h1 className="heading"> CALCULATOR </h1>
<Result values={values} setvalues={setvalues} />
<Keypad
values={values}
setvalues={setvalues}
back={back}
clear={clear}
calculate={calculate}
/>
</div>
</div>
);
}
//hosting
//https://youtu.be/IokPiSZpXDY