-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
61 lines (57 loc) · 1.69 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
49
50
51
52
53
54
55
56
57
58
59
60
61
document.addEventListener('DOMContentLoaded', function () {
const screen = document.getElementById('screen')
const buttons = document.querySelectorAll(".calculator input[type='button']")
// Función para manejar las entradas
function handleInput(value) {
if (value === '=') {
if (screen.value.trim() === '') {
return // No hacer nada si no hay datos en la pantalla
}
try {
const screenValue = screen.value
// Manejo de porcentajes
const regex = /(\d+)%(\d+)/
if (regex.test(screenValue)) {
const matches = screenValue.match(regex)
const percentage = parseFloat(matches[1])
const number = parseFloat(matches[2])
screen.value = ((percentage / 100) * number).toString()
} else if (screenValue.includes('%')) {
screen.value = (
parseFloat(screenValue.replace('%', '')) / 100
).toString()
} else {
screen.value = eval(screenValue)
}
} catch (error) {
screen.value = 'Error'
}
} else if (value === 'C' || value === 'c') {
screen.value = ''
} else if (value === '%') {
screen.value += '%'
} else if (value === '←') {
screen.value = screen.value.slice(0, -1)
} else {
screen.value += value
}
}
// Añadir event listener para botones de la calculadora
buttons.forEach((button) => {
button.addEventListener('click', function () {
handleInput(this.value)
})
})
// Añadir event listener para el teclado
document.addEventListener('keydown', function (event) {
const key = event.key
const validKeys = '0123456789+-*/%=Cc'
if (validKeys.includes(key)) {
handleInput(key)
} else if (key === 'Enter') {
handleInput('=')
} else if (key === 'Backspace') {
handleInput('←')
}
})
})