querySelector y querySelectorAll existen
En el pasado me encontré utilizando jQuery principalmente por los selectores y la potencia que me daban a la hora de trabajar y referenciar a elementos del DOM.
Poco más tarde, me dí cuenta de que en varias oportunidades no era realmente necesario incluir todo jquery, sino que con solo un motor o biblioteca especializada en selectores como sizzle bastaría.
Hoy quiero compartir que querySelector y querySelectorAll existen.
Qué significa esto?
Es importante saber que a la hora de trabajar con el DOM no sólo estamos en la discusión de ir con los amigazos getElementById y getElementsByTagName o con bibliotecas como jQuery.
Con js plano, puro, vanilla, o como udsted quiera llamarle, también podemos obtener elementos del DOM a partir de selectores basados en CSS.
Este post está hecho porque sé que hay mucha gente que no está al tanto de querySelector. O de que tiene tan buen soporte; y yo me incluyo dentro dentro de este último grupo. No hace mucho me dí cuenta de que el tiempo había pasado y que casi todos los browsers se lo bancan lo más bien.
Uso
querySelector es una función que a partir de un selector, devuelve el primer elemento que matchea con ese selector, o null en caso de que no matchee con ningún elemento.
querySelectorAll devuelve un array de elementos con los que el selector matchea. En caso de que esto no ocurra con ningún elemento, el resultado va a ser un array vacío (array con length === 0).
Obviamente, todo esto toma un poco más de sentido cuando tenemos selectores un poco más complejos.. un ejemplo un toque mas práctico:
En fin.. éstas funciones son una herramienta más a tener en cuenta – que en mi caso y algunos casos conocidos estaba siendo menospreciada y casi olvidada.