Crear Script para que muestre un texto según un recuadro cambiado sutilmente [SOLUCIONADO]

Implementación de un Script en JavaScript para Visualización de Texto

En la programación web, una de las acciones más comunes es la manipulación del Document Object Model (DOM) para crear interacciones dinámicas en las páginas. JavaScript se ha consolidado como el lenguaje clave para esta tarea, permitiéndonos desarrollar scripts que respondan a eventos y modifiquen el contenido de nuestros sitios web en tiempo real. En este artículo exploraremos cómo podemos utilizar JavaScript para mostrar diferentes fragmentos de texto al interactuar con diversos recuadros o elementos de nuestra página.

Definiendo el Escenario para el Código

Antes de comenzar, es importante establecer el contexto en el que nuestro código será aplicado. Tomemos como punto de partida una página que contiene varios recuadros o áreas sobre los cuales el usuario puede hacer clic. El objetivo es que, al realizar esta acción, se muestre un texto relacionado con el área seleccionada. Para lograrlo, haremos uso de eventos en JavaScript y manipulación del DOM.

Esquema HTML Básico

Iniciemos estableciendo un esquema HTML sencillo que servirá de lienzo para nuestra implementación:

<div id="container">
    <div class="box" data-text="Texto para el recuadro 1">Recuadro 1</div>
    <div class="box" data-text="Texto para el recuadro 2">Recuadro 2</div>
    <div class="box" data-text="Texto para el recuadro 3">Recuadro 3</div>
</div>
<div id="output"></div>

En este fragmento defino un contenedor div que agrupa tres recuadros, cada uno con una clase box y un atributo data-text que alberga el texto a mostrar. Adicionalmente, contamos con un div donde se visualizará el texto seleccionado, identificado con el ID "output".

Interactividad con JavaScript

Una vez que hemos definido la estructura HTML, procedemos a incorporar la interactividad por medio de JavaScript. Emplearemos un escuchador de eventos (event listener) sobre cada uno de los recuadros:

document.querySelectorAll('.box').forEach(function(box) {
    box.addEventListener('click', function() {
        var texto = this.getAttribute('data-text');
        document.getElementById('output').innerText = texto;
    });
});

En este código, utilizamos querySelectorAll para obtener todos los elementos con la clase box. A cada elemento le añadimos un escuchador para el evento click que, cuando se dispara, captura el valor del atributo data-text y lo asigna al div destinado para el output.

Optimización y Buenas Prácticas

Para asegurar un rendimiento óptimo y mantener el código limpio y mantenible, es esencial seguir las buenas prácticas en el desarrollo de scripts. Una de ellas es evitar la redundancia de código y asegurarse de que cada función realice una tarea específica. Por ende, podemos refactorizar nuestro script anterior de la siguiente manera:

function mostrarTexto(e) {
    var texto = e.target.getAttribute('data-text');
    document.getElementById('output').innerText = texto;
}

document.querySelectorAll('.box').forEach(function(box) {
    box.addEventListener('click', mostrarTexto);
});

De esta forma, extraemos la funcionalidad de mostrar el texto en una función aparte mostrarTexto, que luego es referenciada dentro del escuchador de eventos. Esto no solo hace nuestro código más legible, sino que también facilita la modificación o reutilización de la función en el futuro.

Adaptabilidad y Accesibilidad en la Implementación

Un aspecto de suma importancia en la creación de scripts interactivos es confirmar que estos sean accesibles y se adapten a las diferentes necesidades y dispositivos de los usuarios. Para ello, debemos asegurarnos de que los elementos HTML sean semánticamente correctos y, si es necesario, incluir roles ARIA para una mejor interpretación por lectores de pantalla.

Otro punto a tener en cuenta es que los scripts no siempre estarán activos (por ejemplo, si el usuario tiene desactivado JavaScript en su navegador). Por eso, una buena práctica es que el contenido principal sea accesible aun sin la interactividad, lo que se conoce como diseño degradado progresivo (progressive enhancement).

Añadiendo Estilos para Mejorar la Interfaz

Si bien nuestro enfoque es desarrollar un script que muestre texto, no debemos olvidarnos de la importancia de una buena experiencia de usuario, la cual está también muy ligada a la parte visual. Implementar CSS adecuado para resaltar los elementos interactivos y ofrecer retroalimentación es fundamental para guiar a los usuarios en la interacción con nuestra página:

<style>
    #container .box {
        cursor: pointer;
        padding: 10px;
        margin: 5px;
        border: 1px solid #000;
        display: inline-block;
    }
    #output {
        margin-top: 20px;
        border: 1px solid #000;
        padding: 10px;
    }
</style>

Con este sencillo conjunto de estilos CSS, damos forma a los recuadros indicando al usuario que son elementos con los que puede interactuar, gracias al uso del cursor pointer. Además, el área de visualización del texto seleccionado se encuentra claramente delimitada.

Siguiendo las Directrices SEO en el Desarrollo

Como parte integral de cualquier desarrollo web, incluir prácticas de optimización para motores de búsqueda (SEO) en nuestro código es imprescindible. Aunque JavaScript es principalmente utilizado para la interactividad y no influye directamente en el SEO on-page, es importante asegurarse de que los bots de búsqueda puedan renderizar el contenido JS si este es significativo para el contenido o propósito de la página.

Además, mantener un código limpio y estructurado, utilizar etiquetas semánticas, y asegurarse de que el contenido sea accesible son todos factores que contribuyen positivamente a la visibilidad y posicionamiento de la página en las SERPs (Search Engine Result Pages).

Conclusiones sobre la Creación de Texto Dinámico con JavaScript

La implementación de JavaScript para crear experiencias interactivas y dinámicas es un recurso poderoso en el desarrollo web. Cuando se maneja de manera correcta, permite desarrollar funcionalidades avanzadas que mejoran la usabilidad y la satisfacción de los usuarios. A través de este artículo, hemos explorado una de las muchas maneras en que JavaScript puede utilizarse para mejorar la manera en que los usuarios interactúan con el contenido de una página web.

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