Como saber si en un prompt le di aceptar o cancelar [SOLUCIONADO]

Usar `prompt()` en JavaScript para Capturar la Respuesta del Usuario

Cuando trabajamos con JavaScript, una de las maneras de interactuar directamente con el usuario es a través de la función `prompt()`. Esta función genera una ventana emergente que solicita una entrada de texto al usuario y, a la vez, presenta dos opciones: ‘Aceptar’ y ‘Cancelar’. Es crucial aprender a diferenciar entre estas opciones para gestionar adecuadamente el flujo de un programa.

Entendiendo el Funcionamiento de `prompt()`

Antes de profundizar en cómo distinguir la acción que el usuario ha tomado, es importante comprender cómo funciona la función `prompt()`. Esta función despliega una ventana de diálogos que solicita información y retorna un valor correspondiente a la acción del usuario. El retorno puede ser una cadena de texto si el usuario elige ‘Aceptar’ después de ingresar un dato, o `null` si el usuario decide cancelar la acción.

Ejemplo de Uso y Sintaxis Básica de `prompt()`

Para asegurarnos de manejar correctamente las respuestas, podemos establecer una variable que almacene el valor retornado por `prompt()`. Veamos un ejemplo de cómo se podría invocar esta función y almacenar el valor retornado:

var respuesta = prompt("Por favor, ingresa tu nombre:");

En el código anterior, la variable `respuesta` almacenará la cadena de texto introducida por el usuario, o `null` si el usuario pulsa ‘Cancelar’.

Distinguiendo entre ‘Aceptar’ y ‘Cancelar’ en `prompt()`

Para saber si el usuario ha pulsado ‘Aceptar’ o ‘Cancelar’, debemos verificar si el valor retornado de `prompt()` es `null` o no. Si el usuario elige ‘Cancelar’, la función `prompt()` retorna `null`, y cualquier otra cosa significará que el usuario decidió pulsar ‘Aceptar’.

Implementemos ahora un ejemplo que haga esta verificación:

var respuesta = prompt("Por favor, ingresa tu nombre:");
if (respuesta === null) {
    console.log("El usuario pulsó 'Cancelar'.");
} else {
    console.log("El usuario pulsó 'Aceptar'.");
}

En este fragmento de código, evaluamos si la variable `respuesta` es `null`. Si es así, se interpreta que el usuario no quiso proporcionar su nombre y pulsó ‘Cancelar’. De lo contrario, se acepta que el usuario interactuó positivamente con el diálogo y pulsó ‘Aceptar’.

Es importante **resaltar** que la función `prompt()` también devuelve `null` si el diálogo se cierra por otros medios, como pulsar la tecla ‘Esc’. Esto debe ser considerado si la precisión en la captura de la acción del usuario es imperativa en nuestro programa.

**Manejo Avanzado de `prompt()` para Flujos de Control**

El manejo de la función `prompt()` no se limita solo a detectar si el usuario ha pulsado ‘Aceptar’ o ‘Cancelar’. Se puede conjugar con otras facultades de JavaScript para crear flujos de control más complejos. Por ejemplo, podríamos desarrollar un bucle que siga solicitando al usuario su nombre hasta que este lo proporcione:

var respuesta;
do {
    respuesta = prompt("Por favor, ingresa tu nombre:");
} while (respuesta === null || respuesta === '');

En el código anterior, se sigue presentando la ventana de `prompt()` mientras que la respuesta sea `null` o una cadena vacía. Cabe señalar que con este enfoque el usuario tendrá que proporcionar una respuesta para poder continuar. Esto podría no ser siempre la mejor práctica en términos de experiencia de usuario, pero es útil en ciertos escenarios donde se requiere una entrada obligatoria.

**Validaciones Adicionales y Buenas Prácticas**

Aparte de simplemente verificar si el usuario ha elegido ‘Aceptar’ o ‘Cancelar’, tambien es prudente realizar algunas validaciones adicionales sobre el valor ingresado en el `prompt()`. Por ejemplo, si esperamos un número, es prudente emplear la función `Number.isNaN()` para asegurarnos de que el valor ingresado sea en efecto un número:

var respuesta = prompt("Por favor, ingresa tu edad:");
if (respuesta === null) {
    console.log("El usuario pulsó 'Cancelar'.");
} else if (!Number.isNaN(Number(respuesta))) {
    console.log("El usuario pulsó 'Aceptar' y su edad es " + respuesta);
} else {
    console.log("El usuario pulsó 'Aceptar', pero no ingresó un número.");
}

En este caso, aparte de verificar si el usuario pulsó ‘Aceptar’ o ‘Cancelar’, también comprobamos si lo ingresado es un número válido, mejorando así la robustez de nuestro código.

El trámite de los datos introducidos mediante `prompt()` debe realizarse con cuidado para evitar resultados inesperados o errores en el flujo de ejecución del programa. Se recomienda **validar** no solo la acción tomada por el usuario (‘Aceptar’ o ‘Cancelar’) sino también la **validez de los datos** proporcionados. Esto implica, como se mencionó anteriormente, validar el tipo de entrada y otras posibles condiciones que requiera nuestro programa.

En resumen, el manejo de la función `prompt()` en JavaScript es un recurso de gran utilidad para recoger datos del usuario de manera sencilla. Sin embargo, es tan importante como conocer cómo utilizarla, saber realizar el manejo adecuado de las respuestas proporcionadas por los usuarios. Realizar verificaciones, bucles de control y validaciones adicionales nos permitirá utilizar esta función de forma más eficiente y evitar posibles problemas en la ejecución de nuestros scripts. Con estos conocimientos en mano, podrás crear programas que no solo recojan datos de los usuarios, sino que también interactúen con ellos de una manera más dinámica y controlada.

Esta web utiliza cookies propias y de terceros para su correcto funcionamiento y para fines analíticos y para mostrarte publicidad relacionada con sus preferencias en base a un perfil elaborado a partir de tus hábitos de navegación. Al hacer clic en el botón Aceptar, acepta el uso de estas tecnologías y el procesamiento de tus datos para estos propósitos. Más información
Privacidad