Uninstallme

La Web se ideó cuadrada.

Disparar el evento onclick sobre elementos input de forma remota

22 de Diciembre 2008

En Mocilla Developer Center he encontrado un método cuya existencia desconocía, pero que puede ser de gran utilidad. Se trata del método click, que ejecuta el evento onclick sobre elementos input (botones), checkboxes y radio buttons. En navegadores no basados en Gecko también ejecuta el evento onclick sobre enlaces.

Utilizando este método podemos conseguir de una manera sencilla que un formulario se envíe cuando un campo de texto pierda el foco, por poner un ejemplo.

Su uso es igual al de focus: elemento.click()

Más información

Archivado en Javascript

Comentar

Autocompletado accesible para resultados de búsqueda

20 de Diciembre 2008

En mis últimos trasteos con el blog, he incorporado un “autocompletado” para el formulario de búsqueda. (Utilizo el término autocompletado porque es el más común, aunque yo simplemente lo llamaría resultados de búsqueda instantáneos.)

El funcionamiento se basa en hacer una petición AJAX para la consulta que estamos escribiendo en el campo de búsqueda cada vez que se pulse una tecla, a partir de 3 caracteres escritos. El resultado de esto es una lista que se va actualizando mientras escribimos, con las entradas que coinciden con nuestra búsqueda, con lo que, deseáblemente, los resultados se muestran de forma predictiva.

Ventajas de este sistema:

  • La obtención de resultados es mucho más rápida que si tuviéramos que cargar la página completa.
  • La aparición de la lista de resultados mientras se escribe, puede ahorrar la escritura del literal completo de búsqueda.

Inconvenientes:

  • Los usuarios se quedan sin la posibilidad de agregar la página de resultados a sus marcadores, volver mediante el botón del navegador a una consulta anterior, etc.
  • La página independiente de resultados de búsqueda nos ha quedado un poco desangelada.
  • Las actualizaciones dinámicas de contenido suponen un problema para algunos usuarios como los de lectores de pantalla.

Soluciones a los inconvenientes.

Pérdida de funcionalidad de la interfaz del navegador.

Este problema ha quedado sin resolver, aunque no afirmo que sea insalvable. Yo no conozco la solución.

Un usuario experimentado podría buscar la url de la petición AJAX e introducirla diréctamente en su navegador, o simplemente desactivar Javascript para obtener el comportamiento normal del formulario de búsqueda.

Página independiente de resultados.

Aunque esta página ha quedado bastante triste, se ha procurado que siga teniendo sentido por sí misma al sacarla del contexto para el que está diseñada (la caja de resultados dinámica.)

Para ello se han añadido varios textos ocultos al encabezado visible “Resultados de búsqueda”. Uno contiene los términos de búsqueda y otro el nombre del sitio en el que se ha realizado la búsqueda, de manera que si un usuario llegara a esta página sin haber pasado por el buscador, seguiría teniendo una referencia u orientación general sobre el contenido encontrado.

Por otra parte, se han seguido los principios del Javascript no intrusivo haciendo que los elementos que sólo tienen sentido con Javascript habilitado o que existen solamente para ejecutar una funcionalidad Javascript, no estén en el código HTML, sino que se generen también con Javascript. Para ello se ha reemplazado el enlace que aparece en la página de resultados a la página principal de este sitio, por el botón de cerrar que aparece en la caja de resultados.

Contenidos dinámicos VS lectores de pantalla.

Como comentaba en un post anterior, los usuarios de lectores de pantalla tienen dificultades para enterarse de las actualizaciones dinámicas de contenido mediante Javascript. En primer lugar no pueden apreciar visualmente los cambios, y en segundo lugar, los lectores de pantalla leen el contenido de la página de manera lineal, a partir de una “captura del DOM” (buffer virtual) que guardan al cargar la página.

Esto último supone, que mientras el contenido ha cambiado, el lector de pantalla sigue usando una versión no actualizada del DOM. En las últimas versiones del lector de pantalla JAWS, este problema se ha solucionado parcialmente refrescando el buffer virtual cada cierto tiempo para evitar que se use una versión desactualizada de la página. Aun así, la aparición o modificación de contenidos sigue resultando un problema, ya que, aunque el lector de pantalla actualice el buffer virtual, el usuario no tiene forma de saber automáticamente que el contenido ha cambiado o dónde se ha producido esa actualización de contenido.

Una de las medidas más efectivas para solucionar este problema, o al menos minimizarlo, consiste simplemente en llevar el foco a la capa en la que se generan los resultados de búsqueda, que por otra parte, y por razones de posicionamiento CSS, no aparece inmediátamente después del formulario de búsqueda, sino al final del documento. Para ello simplemente le hemos asignado un valor negativo (-1) al atributo tabindex, para que pueda recibir el foco mediante Javascript (elemento.focus();) pero no aparezca en el orden natural de tabulación de la página.

El atributo tabindex no valida en elementos que no sean campos de formulario o enlaces, por lo que se ha añadido mediante Javascript.

Con esto conseguimos que al desenfocar el campo de búsqueda (evento onblur), la capa con los datos actualizados reciba inmediátamente el foco y pueda ser leída a continuación.

WAI-ARIA para los más avanzados.

La solución de llevar el foco al elemento actualizado, resulta efectiva en Internet Explorer (6 y 7) usando JAWS y NVDA, pero para los navegadores que actualmente soportan WAI-ARIA (Firefox 2 y superiores y Opera), hemos añadido unos cuantos atributos que informan además, sobre la cantidad de contenido que se actualizará en un área dinámica, la prioridad con que el lector de pantalla debe anunciar la actualización o el papel que cumple el área actualizada en el documento (es un contenido independiente, complementario, navegación, etc.)

Para conocer una lista de las posibilidades de WAI-ARIA, recomiendo echarle un vistazo a los ejemplos de ARIA que publican en iCITA.

Después de varias combinaciones y pruebas con JAWS 9, NVDA y el plugin para Firefox, Firevox, he decidio usar las siguientes propiedades y atributos para la capa de los resultados:


'aria-live': 'assertive',
'aria-relevant': 'all',
'aria-atomic': 'true'

También tengo que comentar, que el lector de pantalla con el que he obtenido unos resultados más parecidos a los esperados, ha sido el lector gratuito NVDA.

Más información:

Archivado en Accesibilidad, Javascript

3 Comentarios

Evitar la introducción de caracteres no numéricos en campos de texto con Javascript

18 de Diciembre 2008

Una buena forma de evitar errores del usuario al rellenar formularios, es no dar lugar a que se produzcan y uno de los casos en los que esto es posible, es el de los típicos formularios que solicitan un número de cuenta bancaria.

La siguiente función usada con el evento onkeydown en campos de texto, comprueba que el caracter introducido sea la tecla tabulador o delete, cualquier número del 0 al 9 en el teclado normal, cualquier número del 0 al 9 en el teclado numérico, la tecla control o F5.


function esValorNumerico(event){
	if(!event) event = event || window.event;
	return (
		(event.keyCode > 7 && event.keyCode < 10)       // delete (8) o tabulador (9)
		|| (event.keyCode > 47 && event.keyCode < 60)   // números del teclado
		|| (event.keyCode > 95 && event.keyCode < 106)  // números del teclado numérico
		|| event.keyCode == 17   // Ctrl
		|| event.keyCode == 116  // F5
	)
}

Evitaríamos la introducción de cualquier caracter que no sea uno de los especificados, devolviendo false si la condición no se cumple.


inputs[i].onkeydown = function(event){
	if(!esValorNumerico(event)) return false;
}

¿Por qué con el evento onkeydown y no con onkeypress?

Por suerte, onkeydown funciona igual en todos los navegadores. Onkeypress sin embargo, devuelve 0 como keyCode para las teclas especiales, entre las que se encuentran los números, además de presentar diferencias importantes de funcionamiento entre Internet Explorer y el resto de navegadores.

Por cierto, con este problemilla he tenido la ocasión de comprobar que los códigos que se pueden encontrar por Internet para realizar esta acción son bastante prehistóricos (optimizados para Netscape 4). ¿Tendrán algo que ver los frameworks Javascript…?

Más información

Archivado en How to, Javascript

Comentar

Rollover de imágenes en HTML (elemento IMG) sin Javascript

19 de Noviembre 2008

Los rollovers de imágenes con javascript casi han pasado a la historia desde que podemos hacerlo de manera mucho más fácil y limpia con CSS, pero para los casos en los que, por la razón que sea, sea necesario que la imagen del rollover esté como elemento <img> en el código HTML, podemos conseguirlo utilizando sólo CSS.

El único requisito para que el rollover funcione en Internet Explorer 6, es que la imagen esté contenida en un enlace. En el caso de que la imagen sea un botón de tipo image, necesitaremos añadir una clase por Javascript, ya que Explorer 6 ignora el :hover sobre cualquier elemento que no sea un enlace.

El principal inconveniente de los rollovers con Javascript es que necesitamos dos imágenes para cada estado. Con esta técnica, usamos una sola imagen con sus dos estados, como lo haríamos con un rollover “normal” con CSS.

Imagen usada para el rollover:

La técnica se basa en conseguir un efecto “clip” mediante el uso de overflow: hidden. Para ello metemos la imagen en un elemento <span> al que damos el ancho y alto del área visible de cada estado de la imagen. En el ejemplo 22 píxeles. Damos display block y posición relativa para que Internet Explorer sea feliz (en otros navegadores no es necesaria la posición relativa)

Por último, damos al enlace en estado hover, posición relativa y una posición negativa igual a la altura de la imagen.  En este caso no es necesario dejar un margen en blanco entre ambos estados de la imagen para prevenir que al aumentar el tamaño de texto de la página se vea parte de la imagen para el estado hover, como ocurre con los navegadores que no hacen zoom (Firefox 2, Google Chrome, Internet Explorer 6) y los rollovers con CSS mediante imágenes de fondo, ya que que podremos aplicar dimensiones mediante CSS diréctamente a la imagen, permitiendo que se dimensione al aumentar el tamaño de texto.

El código HTML utilizado sería el siguiente:


<span class="img-rollover">
<a href="#"><img alt="A" src="boton-a.png" /></a>
</span>

Y el código CSS:


span.img-rollover{ width: 22px; height: 22px; overflow: hidden; display: block; position: relative; }
span.img-rollover a:hover{ top: -22px; position: relative;}

El resultado:

Técnica inspirada en el botón de buscar de The Man in Blue

Archivado en Buenas ideas, CSS, How to

4 Comentarios

POO en javascript: uso y ámbito de this

26 de Septiembre 2008

En las diapositivas del post anterior sobre este tema, explicaba la sintaxis de la notación literal de objetos y comentaba el uso de la palabra reservada this para acceder a las propiedades y métodos de un objeto.

Continúa en "POO en javascript: uso y ámbito de this"

Archivado en How to, Javascript

Comentar

POO en javascript usando Notación Literal de Objetos (1)

23 de Septiembre 2008

Llevo tiempo queriendo escribir un post sobre este tema, pero lo voy dejando porque me asusta la idea de escribir un tocho infumable, así que he decidido hacerlo de una forma más visual que espero resulte lo más clara posible. Ya veremos cómo lo hago en próximas entregas.
Continúa en "POO en javascript usando Notación Literal de Objetos (1)"

Archivado en How to, Javascript

1 Comentario

Crear efectos de transición con Mootools

29 de Agosto 2008

Mootools es una librería Javascript muy parecida a Prototype pero que permite crear efectos de movimiento, opacidad, color, etc. sin necesidad de usar una librería adicional como Scriptaculous. Su peso comprimida es de 60Kb y tiene una muy buena documentación también disponible offline. Además es una de las librerías Javascript que podemos encontrar en las librerías Ajax de Google.

Para crear efectos de transición con Mootools usamos la clase Fx.

Continúa en "Crear efectos de transición con Mootools"

Archivado en CSS, Javascript

1 Comentario

Javascript y accesibilidad

15 de Agosto 2008

Para muchos de los que comenzamos en esto en la época de la revolución CSS, el boom del Zen Garden (en España) y la agonía de la maquetación con tablas, Javascript ha sido visto como algo sucio, molesto y que ponía en peligro la accesibilidad de las páginas.

No es de extrañar teniendo en cuenta que en aquella época veíamos que Javascript servía para que objetos de todo tipo persiguieran el cursor por la pantalla, nevara sobre las páginas, se deshabilitara el botón derecho del ratón, en la barra de estado del navegador apareciera un mensaje en movimiento y sobre todo, para lanzar popups sin nuestro consentimiento.

Continúa en "Javascript y accesibilidad"

Archivado en Accesibilidad, Javascript

1 Comentario

Event bubbling y event capturing

12 de Agosto 2008

Event bubbling y event capturing son dos conceptos de javascript relativos al orden en que las funciones asociadas a un mismo tipo de evento deben ejecutarse.  Aunque es posible que en la práctica este comportamiento de los eventos no suponga un problema, hay que saber que el burbujeo o event bubbling siempre ocurre y hay que tenerlo en cuenta en eventos de tipo mouseover, mousemove, mouseout, etc.

Continúa en "Event bubbling y event capturing"

Archivado en Javascript

Comentar

Evitar la activación de una función asociada a un evento onkeypress con la tecla tabulador

1 de Julio 2008

Sintiendo ser un poco monotemática y cansina con el tema del onkeypress, dejo un ejemplo de menú desplegable con javascript en el que se ha usado una función para evitar que la tecla tabulador disparé la función asociada a un evento onkeypress en Firefox, perimitiendo así la navegación mediante teclado.

Continúa en "Evitar la activación de una función asociada a un evento onkeypress con la tecla tabulador"

Archivado en Accesibilidad, Javascript

Comentar

 Página 1 de 2  1  2 »