En el post anterior hablé sobre el DOM y cómo Javascript trabaja con él. En esta ocasión explicaré los diferentes métodos para seleccionar elementos con JavaScript. Una vez que se construye el árbol de nodos DOM, es posible emplear funciones para poder acceder de forma directa a cualquier nodo del árbol. Al acceder a un nodo, podemos manipularlo: acceder a su valor, cambiar un valor, moverlo… , o crear nuevos elementos dentro de o a partir de él.
En este post explicaré las diferentes funciones que nos permiten acceder o seleccionar elementos con JavaScript. Aunque, es importante recordar que para seleccionar elementos, es importante que el árbol DOM haya sido construido totalmente, es decir, cuando la página HTML se haya cargado completamente.
Seleccionar elementos con getElementsByTagName()
Esta función nos permite obtener todos los elementos cuya etiqueta sea igual al parámetro que le pasamos a la función. Por ejemplo, para seleccionar todos los h1 de una página html.
1 2 3 4 5 6 |
<h1>Título 1</h1> <h1>Título 2</h1> <script> var titulos = document.getElementsByTagName("h1"); </script> |
Delante de la función, vemos un documento. Ahí se indica a partir de qué nodo se realiza la búsqueda de elementos. Como queremos obtener todo los títulos de la página, usamos document.
Esta función devuelve un array de todos los nodos que cumplen la condición de que su etiqueta coincide con el argumento pasado. El valor al ser un array de nodos, cada uno se trataría como un objeto. Para obtener el texto del primer título.
1 2 3 |
var primerTitulo = titulos[0].innerHTML;; alert(primerTitulo); |
Como comenté hace un momento, lo que va precedido de la función es a partir de onde se realiza la búsquueda. Por tanto, vamos a mostrar como se buscaría los elementos span que estén dentro del primer título
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
<span>Este no se selecciona</span> <h1>Título <span>1</span></h1> <h1>Título 2</h1> <script> var titulos = document.getElementsByTagName("h1"); var primerTitulo = titulos[0]; var etiquetas = primerTitulo.getElementsByTagName("span"); alert(etiquetas[0].innerHTML) </script> |
De esta forma etiquetas tendría todos los elementos span que estén dentro del primer título.
Seleccionar elementos por nombre con getElementsByName()
Esta función es similar al anterior, pero esta vez se buscan los elementos cuyo atributo name coincida con el parámetro. Por ejemplo, tenemos un formulario y queremos seleccionarlo..
1 2 3 4 5 6 7 8 |
<form name="formularioRegistro"> ... </form> <script> var formulario = document.getElementsByName("formularioRegistro"); </script> |
Esta funcion es muy útil cuando queremos seleccionar un input tipo radio o tipo checkbox ya que el atributo name es común para ellos para indicar que están relacionados.
1 2 3 4 5 6 7 8 9 |
<input type="radio" name="valores" value="valor1"/>Valor 1 <input type="radio" name="valores" value="valor2"/>Valor 2 <input type="radio" name="valores" value="valor3"/>Valor 3 <script> var valores = document.getElementsByName("valores"); alert(valores[1].value); </script> |
Seleccionar elementos por su id getElementById()
Esta función es la más utilizada para seleccionar elementos con JavaScript y nos devuelve elemento cuyo atributo id coincida con el parámetro indicado en la función. Como el atributo id debe ser único para cada elemento, la función devuelve únicamente el nodo deseado.
1 2 3 4 5 6 |
<p id="parrafo">Párrafo de prueba</p> <script> var parrafo = document.getElementById("parrafo"); alert(parrafo.innerHTML); </script> |
A modo de curiosidad, en IE6 esta función devuelve aquellos elementos cuyo atributo name coincida con el argumento pasado a la función.
Espero que os haya gustado este post de cómo seleccionar elementos con JavaScript. A seguir picando 🙂