XML DOM - Guía rápida
los Documento Oobjeto Model (DOM) es un estándar W3C. Define un estándar para acceder a documentos como HTML y XML.
La definición de DOM tal como la pone el W3C es:
El Modelo de objetos de documento (DOM) es una interfaz de programación de aplicaciones (API) para documentos HTML y XML. Define la estructura lógica de los documentos y la forma en que se accede y se manipula un documento.
DOM define los objetos y propiedades y métodos (interfaz) para acceder a todos los elementos XML. Está dividido en 3 partes / niveles diferentes:
Core DOM - modelo estándar para cualquier documento estructurado
XML DOM - modelo estándar para documentos XML
HTML DOM - modelo estándar para documentos HTML
XML DOM es un modelo de objetos estándar para XML. Los documentos XML tienen una jerarquía de unidades de información llamadas nodos ; DOM es una interfaz de programación estándar para describir esos nodos y las relaciones entre ellos.
Como XML DOM también proporciona una API que permite a un desarrollador agregar, editar, mover o eliminar nodos en cualquier punto del árbol para crear una aplicación.
A continuación se muestra el diagrama de la estructura DOM. El diagrama muestra que el analizador evalúa un documento XML como una estructura DOM atravesando cada nodo.
Ventajas de XML DOM
Las siguientes son las ventajas de XML DOM.
XML DOM es independiente del lenguaje y la plataforma.
XML DOM es traversable - La información en XML DOM está organizada en una jerarquía que permite al desarrollador navegar por la jerarquía en busca de información específica.
XML DOM es modifiable - Es de naturaleza dinámica, lo que le brinda al desarrollador un alcance para agregar, editar, mover o eliminar nodos en cualquier punto del árbol.
Desventajas de XML DOM
Consume más memoria (si la estructura XML es grande) ya que el programa escrito una vez permanece en la memoria todo el tiempo hasta que se elimine explícitamente.
Debido al uso extensivo de la memoria, su velocidad operativa, en comparación con SAX, es más lenta.
Ahora que sabemos lo que significa DOM, veamos qué es una estructura DOM. Un documento DOM es una colección de nodos o piezas de información, organizadas en una jerarquía. Algunos tipos de nodos pueden tener nodos secundarios de varios tipos y otros son nodos hoja que no pueden tener nada debajo de ellos en la estructura del documento. A continuación se muestra una lista de los tipos de nodos, con una lista de los tipos de nodos que pueden tener como hijos:
Document - Elemento (máximo uno), Instrucciones de procesamiento, Comentario, Tipo de documento (máximo uno)
DocumentFragment - Elemento, ProcessingInstruction, Comment, Text, CDATASection, EntityReference
EntityReference - Elemento, ProcessingInstruction, Comment, Text, CDATASection, EntityReference
Element - Elemento, Texto, Comentario, Instrucción de procesamiento, Sección CDATAS, Referencia de entidad
Attr - Texto, EntityReference
ProcessingInstruction - sin hijos
Comment - sin hijos
Text - sin hijos
CDATASection - sin hijos
Entity - Elemento, ProcessingInstruction, Comment, Text, CDATASection, EntityReference
Notation - sin hijos
Ejemplo
Considere la representación DOM del siguiente documento XML node.xml.
<?xml version = "1.0"?>
<Company>
<Employee category = "technical">
<FirstName>Tanmay</FirstName>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
</Employee>
<Employee category = "non-technical">
<FirstName>Taniya</FirstName>
<LastName>Mishra</LastName>
<ContactNo>1234667898</ContactNo>
</Employee>
</Company>
El modelo de objeto de documento del documento XML anterior sería el siguiente:
Del diagrama de flujo anterior, podemos inferir:
El objeto de nodo solo puede tener un objeto de nodo principal . Este ocupa la posición por encima de todos los nodos. Aquí está Company .
El nodo principal puede tener varios nodos denominados nodos secundarios . Estos nodos secundarios pueden tener nodos adicionales denominados nodos de atributo . En el ejemplo anterior, tenemos dos nodos de atributo Técnico y No técnico . El nodo de atributo no es en realidad un hijo del nodo de elemento, pero todavía está asociado con él.
Estos nodos secundarios, a su vez, pueden tener varios nodos secundarios. El texto dentro de los nodos se llama nodo de texto .
Los objetos de nodo del mismo nivel se denominan hermanos.
El DOM identifica -
los objetos para representar la interfaz y manipular el documento.
la relación entre los objetos y las interfaces.
En este capítulo, estudiaremos sobre los nodos DOM XML . Cada DOM XML contiene la información en unidades jerárquicas llamadas Nodos y el DOM describe estos nodos y la relación entre ellos.
Tipos de nodo
El siguiente diagrama de flujo muestra todos los tipos de nodos:
Los tipos más comunes de nodos en XML son:
Document Node- La estructura completa del documento XML es un nodo de documento .
Element Node- Cada elemento XML es un nodo de elemento . Este es también el único tipo de nodo que puede tener atributos.
Attribute Node- Cada atributo se considera un nodo de atributo . Contiene información sobre un nodo de elemento, pero en realidad no se considera hijos del elemento.
Text Node- Los textos del documento se consideran nodo de texto . Puede constar de más información o simplemente de espacios en blanco.
Algunos tipos de nodos menos comunes son:
CData Node- Este nodo contiene información que no debe ser analizada por el analizador. En su lugar, debería transmitirse como texto sin formato.
Comment Node - Este nodo incluye información sobre los datos y, por lo general, la aplicación lo ignora.
Processing Instructions Node - Este nodo contiene información específicamente dirigida a la aplicación.
Document Fragments Node
Entities Node
Entity reference nodes
Notations Node
En este capítulo, estudiaremos sobre el árbol de nodos XML DOM . En un documento XML, la información se mantiene en una estructura jerárquica; esta estructura jerárquica se denomina árbol de nodos . Esta jerarquía permite al desarrollador navegar por el árbol en busca de información específica, por lo que los nodos pueden acceder. El contenido de estos nodos se puede actualizar.
La estructura del árbol de nodos comienza con el elemento raíz y se extiende a los elementos secundarios hasta el nivel más bajo.
Ejemplo
El siguiente ejemplo muestra un documento XML simple, cuya estructura del árbol de nodos se muestra en el diagrama siguiente:
<?xml version = "1.0"?>
<Company>
<Employee category = "Technical">
<FirstName>Tanmay</FirstName>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
</Employee>
<Employee category = "Non-Technical">
<FirstName>Taniya</FirstName>
<LastName>Mishra</LastName>
<ContactNo>1234667898</ContactNo>
</Employee>
</Company>
Como se puede ver en el ejemplo anterior, cuya representación pictórica (de su DOM) es la que se muestra a continuación:
El nodo más alto de un árbol se llama root. losrootEl nodo es <Company> que a su vez contiene los dos nodos de <Employee>. Estos nodos se conocen como nodos secundarios.
El nodo hijo <Employee> del nodo raíz <Company>, a su vez, consta de su propio nodo hijo (<FirstName>, <LastName>, <ContactNo>).
Los dos nodos secundarios, <Empleado> tienen valores de atributo Técnico y No técnico, se denominan nodos de atributo .
El texto dentro de cada nodo se llama nodo de texto .
XML DOM - Métodos
DOM como API contiene interfaces que representan diferentes tipos de información que se pueden encontrar en un documento XML, como elementos y texto. Estas interfaces incluyen los métodos y propiedades necesarios para trabajar con estos objetos. Las propiedades definen la característica del nodo, mientras que los métodos dan la forma de manipular los nodos.
La siguiente tabla enumera las clases e interfaces DOM:
S.No. | Interfaz y descripción |
---|---|
1 | DOMImplementation Proporciona varios métodos para realizar operaciones que son independientes de cualquier instancia particular del modelo de objetos de documento. |
2 | DocumentFragment Es el objeto de documento "ligero" o "mínimo", y (como la superclase de Documento) ancla el árbol XML / HTML en un documento completo. |
3 | Document Representa el nodo de nivel superior del documento XML, que proporciona acceso a todos los nodos del documento, incluido el elemento raíz. |
4 | Node Representa el nodo XML. |
5 | NodeList Representa una lista de solo lectura de objetos Node . |
6 | NamedNodeMap Representa colecciones de nodos a los que se puede acceder por su nombre. |
7 | Data Extiende Node con un conjunto de atributos y métodos para acceder a datos de caracteres en el DOM. |
8 | Attribute Representa un atributo en un objeto Element. |
9 | Element Representa el nodo del elemento. Deriva de Node. |
10 | Text Representa el nodo de texto. Deriva de CharacterData. |
11 | Comment Representa el nodo de comentario. Deriva de CharacterData. |
12 | ProcessingInstruction Representa una "instrucción de procesamiento". Se utiliza en XML como una forma de mantener información específica del procesador en el texto del documento. |
13 | CDATA Section Representa la sección CDATA. Deriva del texto. |
14 | Entity Representa una entidad. Deriva de Node. |
15 | EntityReference Esto representa una referencia de entidad en el árbol. Deriva de Node. |
Discutiremos los métodos y propiedades de cada una de las interfaces anteriores en sus respectivos capítulos.
En este capítulo, estudiaremos sobre la carga y el análisis de XML .
Para describir las interfaces proporcionadas por la API, el W3C utiliza un lenguaje abstracto llamado Lenguaje de definición de interfaz (IDL). La ventaja de usar IDL es que el desarrollador aprende a usar DOM con su idioma favorito y puede cambiar fácilmente a un idioma diferente.
La desventaja es que, dado que es abstracto, los desarrolladores web no pueden utilizar el IDL directamente. Debido a las diferencias entre los lenguajes de programación, necesitan tener mapeo, o enlace, entre las interfaces abstractas y sus lenguajes concretos. DOM se ha asignado a lenguajes de programación como Javascript, JScript, Java, C, C ++, PLSQL, Python y Perl.
En las siguientes secciones y capítulos, usaremos Javascript como nuestro lenguaje de programación para cargar archivos XML.
Analizador
Un analizador es una aplicación de software que está diseñada para analizar un documento, en nuestro caso un documento XML y hacer algo específico con la información. Algunos de los analizadores basados en DOM se enumeran en la siguiente tabla:
S. No | Analizador y descripción |
---|---|
1 | JAXP API Java de Sun Microsystem para análisis XML (JAXP) |
2 | XML4J Analizador XML de IBM para Java (XML4J) |
3 | msxml El analizador XML de Microsoft (msxml) versión 2.0 está integrado en Internet Explorer 5.5 |
4 | 4DOM 4DOM es un analizador para el lenguaje de programación Python |
5 | XML::DOM XML :: DOM es un módulo de Perl para manipular documentos XML usando Perl |
6 | Xerces Analizador de Java Xerces de Apache |
En una API basada en árboles como DOM, el analizador recorre el archivo XML y crea los objetos DOM correspondientes. Entonces puedes atravesar la estructura DOM de un lado a otro.
Carga y análisis de XML
Al cargar un documento XML, el contenido XML puede presentarse en dos formas:
- Directamente como archivo XML
- Como cadena XML
Contenido como archivo XML
El siguiente ejemplo demuestra cómo cargar datos XML ( node.xml ) utilizando Ajax y Javascript cuando el contenido XML se recibe como un archivo XML. Aquí, la función Ajax obtiene el contenido de un archivo xml y lo almacena en XML DOM. Una vez que se crea el objeto DOM, se analiza.
<!DOCTYPE html>
<html>
<body>
<div>
<b>FirstName:</b> <span id = "FirstName"></span><br>
<b>LastName:</b> <span id = "LastName"></span><br>
<b>ContactNo:</b> <span id = "ContactNo"></span><br>
<b>Email:</b> <span id = "Email"></span>
</div>
<script>
//if browser supports XMLHttpRequest
if (window.XMLHttpRequest) { // Create an instance of XMLHttpRequest object.
code for IE7+, Firefox, Chrome, Opera, Safari xmlhttp = new XMLHttpRequest();
} else { // code for IE6, IE5
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
// sets and sends the request for calling "node.xml"
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
// sets and returns the content as XML DOM
xmlDoc = xmlhttp.responseXML;
//parsing the DOM object
document.getElementById("FirstName").innerHTML =
xmlDoc.getElementsByTagName("FirstName")[0].childNodes[0].nodeValue;
document.getElementById("LastName").innerHTML =
xmlDoc.getElementsByTagName("LastName")[0].childNodes[0].nodeValue;
document.getElementById("ContactNo").innerHTML =
xmlDoc.getElementsByTagName("ContactNo")[0].childNodes[0].nodeValue;
document.getElementById("Email").innerHTML =
xmlDoc.getElementsByTagName("Email")[0].childNodes[0].nodeValue;
</script>
</body>
</html>
node.xml
<Company>
<Employee category = "Technical" id = "firstelement">
<FirstName>Tanmay</FirstName>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Non-Technical">
<FirstName>Taniya</FirstName>
<LastName>Mishra</LastName>
<ContactNo>1234667898</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Management">
<FirstName>Tanisha</FirstName>
<LastName>Sharma</LastName>
<ContactNo>1234562350</ContactNo>
<Email>[email protected]</Email>
</Employee>
</Company>
La mayoría de los detalles del código están en el código del script.
Internet Explorer usa ActiveXObject ("Microsoft.XMLHTTP") para crear una instancia del objeto XMLHttpRequest, otros navegadores usan el método XMLHttpRequest () .
la responseXML transforma el contenido XML directamente en el DOM XML.
Una vez que el contenido XML se transforma en DOM XML de JavaScript, puede acceder a cualquier elemento XML utilizando los métodos y propiedades de DOM de JS. Hemos utilizado las propiedades DOM como childNodes , nodeValue y métodos DOM como getElementsById (ID), getElementsByTagName (tags_name).
Ejecución
Guarde este archivo como loadingexample.html y ábralo en su navegador. Recibirá el siguiente resultado:
Contenido como cadena XML
El siguiente ejemplo demuestra cómo cargar datos XML utilizando Ajax y Javascript cuando el contenido XML se recibe como archivo XML. Aquí, la función Ajax obtiene el contenido de un archivo xml y lo almacena en XML DOM. Una vez que se crea el objeto DOM, se analiza.
<!DOCTYPE html>
<html>
<head>
<script>
// loads the xml string in a dom object
function loadXMLString(t) { // for non IE browsers
if (window.DOMParser) {
// create an instance for xml dom object parser = new DOMParser();
xmlDoc = parser.parseFromString(t,"text/xml");
}
// code for IE
else { // create an instance for xml dom object
xmlDoc = new ActiveXObject("Microsoft.XMLDOM");
xmlDoc.async = false;
xmlDoc.loadXML(t);
}
return xmlDoc;
}
</script>
</head>
<body>
<script>
// a variable with the string
var text = "<Employee>";
text = text+"<FirstName>Tanmay</FirstName>";
text = text+"<LastName>Patil</LastName>";
text = text+"<ContactNo>1234567890</ContactNo>";
text = text+"<Email>[email protected]</Email>";
text = text+"</Employee>";
// calls the loadXMLString() with "text" function and store the xml dom in a variable
var xmlDoc = loadXMLString(text);
//parsing the DOM object
y = xmlDoc.documentElement.childNodes;
for (i = 0;i<y.length;i++) {
document.write(y[i].childNodes[0].nodeValue);
document.write("<br>");
}
</script>
</body>
</html>
La mayoría de los detalles del código están en el código del script.
Internet Explorer usa ActiveXObject ("Microsoft.XMLDOM") para cargar datos XML en un objeto DOM, otros navegadores usan la función DOMParser () y el método parseFromString (text, 'text / xml') .
El texto variable debe contener una cadena con contenido XML.
Una vez que el contenido XML se ha transformado en DOM XML de JavaScript, puede acceder a cualquier elemento XML utilizando propiedades y métodos DOM de JS. Hemos utilizado propiedades DOM como childNodes , nodeValue .
Ejecución
Guarde este archivo como loadingexample.html y ábralo en su navegador. Verá la siguiente salida:
Ahora que vimos cómo el contenido XML se transforma en DOM XML XML, ahora puede acceder a cualquier elemento XML utilizando los métodos DOM XML.
En este capítulo, discutiremos XML DOM Traversing. Estudiamos en el capítulo anterior cómo cargar un documento XML y analizar el objeto DOM así obtenido. Este objeto DOM analizado se puede atravesar. Atravesar es un proceso en el que el bucle se realiza de manera sistemática recorriendo todos y cada uno de los elementos paso a paso en un árbol de nodos.
Ejemplo
El siguiente ejemplo (traverse_example.htm) demuestra la travesía DOM. Aquí atravesamos cada nodo hijo del elemento <Employee>.
<!DOCTYPE html>
<html>
<style>
table,th,td {
border:1px solid black;
border-collapse:collapse
}
</style>
<body>
<div id = "ajax_xml"></div>
<script>
//if browser supports XMLHttpRequest
if (window.XMLHttpRequest) {// Create an instance of XMLHttpRequest object.
code for IE7+, Firefox, Chrome, Opera, Safari
var xmlhttp = new XMLHttpRequest();
} else {// code for IE6, IE5
var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
// sets and sends the request for calling "node.xml"
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
// sets and returns the content as XML DOM
var xml_dom = xmlhttp.responseXML;
// this variable stores the code of the html table
var html_tab = '<table id = "id_tabel" align = "center">
<tr>
<th>Employee Category</th>
<th>FirstName</th>
<th>LastName</th>
<th>ContactNo</th>
<th>Email</th>
</tr>';
var arr_employees = xml_dom.getElementsByTagName("Employee");
// traverses the "arr_employees" array
for(var i = 0; i<arr_employees.length; i++) {
var employee_cat = arr_employees[i].getAttribute('category');
// gets the value of 'category' element of current "Element" tag
// gets the value of first child-node of 'FirstName'
// element of current "Employee" tag
var employee_firstName =
arr_employees[i].getElementsByTagName('FirstName')[0].childNodes[0].nodeValue;
// gets the value of first child-node of 'LastName'
// element of current "Employee" tag
var employee_lastName =
arr_employees[i].getElementsByTagName('LastName')[0].childNodes[0].nodeValue;
// gets the value of first child-node of 'ContactNo'
// element of current "Employee" tag
var employee_contactno =
arr_employees[i].getElementsByTagName('ContactNo')[0].childNodes[0].nodeValue;
// gets the value of first child-node of 'Email'
// element of current "Employee" tag
var employee_email =
arr_employees[i].getElementsByTagName('Email')[0].childNodes[0].nodeValue;
// adds the values in the html table
html_tab += '<tr>
<td>'+ employee_cat+ '</td>
<td>'+ employee_firstName+ '</td>
<td>'+ employee_lastName+ '</td>
<td>'+ employee_contactno+ '</td>
<td>'+ employee_email+ '</td>
</tr>';
}
html_tab += '</table>';
// adds the html table in a html tag, with id = "ajax_xml"
document.getElementById('ajax_xml').innerHTML = html_tab;
</script>
</body>
</html>
Este código carga node.xml .
El contenido XML se transforma en un objeto DOM XML de JavaScript.
Se obtiene la matriz de elementos (con etiqueta Element) utilizando el método getElementsByTagName ().
A continuación, recorremos esta matriz y mostramos los valores del nodo secundario en una tabla.
Ejecución
Guarde este archivo como traverse_example.html en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). Recibirá el siguiente resultado:
Hasta ahora hemos estudiado la estructura DOM, cómo cargar y analizar el objeto DOM XML y atravesar los objetos DOM. Aquí veremos cómo podemos navegar entre nodos en un objeto DOM. El DOM XML consta de varias propiedades de los nodos que nos ayudan a navegar a través de los nodos, como:
- parentNode
- childNodes
- firstChild
- lastChild
- nextSibling
- previousSibling
A continuación se muestra un diagrama de un árbol de nodos que muestra su relación con los otros nodos.
DOM - Nodo principal
Esta propiedad especifica el nodo padre como un objeto de nodo.
Ejemplo
El siguiente ejemplo (navigate_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML. Luego, el objeto DOM se navega al nodo principal a través del nodo secundario:
<!DOCTYPE html>
<html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
var y = xmlDoc.getElementsByTagName("Employee")[0];
document.write(y.parentNode.nodeName);
</script>
</body>
</html>
Como puede ver en el ejemplo anterior, el nodo hijo Empleado navega a su nodo padre.
Ejecución
Guarde este archivo como navigate_example.html en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). En la salida, obtenemos el nodo padre de Empleado , es decir, Compañía .
Primer hijo
Esta propiedad es de tipo Node y representa el primer nombre secundario presente en NodeList.
Ejemplo
El siguiente ejemplo (first_node_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML, luego navega al primer nodo secundario presente en el objeto DOM.
<!DOCTYPE html>
<html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
function get_firstChild(p) {
a = p.firstChild;
while (a.nodeType != 1) {
a = a.nextSibling;
}
return a;
}
var firstchild = get_firstChild(xmlDoc.getElementsByTagName("Employee")[0]);
document.write(firstchild.nodeName);
</script>
</body>
</html>
La función get_firstChild (p) se usa para evitar los nodos vacíos. Ayuda a obtener el elemento firstChild de la lista de nodos.
x = get_firstChild(xmlDoc.getElementsByTagName("Employee")[0])obtiene el primer nodo hijo para el nombre de etiqueta Empleado .
Ejecución
Guarde este archivo como first_node_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). En la salida, obtenemos el primer nodo hijo de Empleado, es decir, Nombre .
Último niño
Esta propiedad es de tipo Node y representa el último nombre secundario presente en NodeList.
Ejemplo
El siguiente ejemplo (last_node_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML, luego navega hasta el último nodo hijo presente en el objeto DOM xml.
<!DOCTYPE html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
function get_lastChild(p) {
a = p.lastChild;
while (a.nodeType != 1){
a = a.previousSibling;
}
return a;
}
var lastchild = get_lastChild(xmlDoc.getElementsByTagName("Employee")[0]);
document.write(lastchild.nodeName);
</script>
</body>
</html>
Ejecución
Guarde este archivo como last_node_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). En la salida, obtenemos el último nodo secundario de Empleado, es decir, Correo electrónico .
Proximo hermano
Esta propiedad es de tipo Node y representa el siguiente hijo, es decir, el siguiente hermano del elemento hijo especificado presente en NodeList.
Ejemplo
El siguiente ejemplo (nextSibling_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML que navega inmediatamente al siguiente nodo presente en el documento xml.
<!DOCTYPE html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
}
else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
function get_nextSibling(p) {
a = p.nextSibling;
while (a.nodeType != 1) {
a = a.nextSibling;
}
return a;
}
var nextsibling = get_nextSibling(xmlDoc.getElementsByTagName("FirstName")[0]);
document.write(nextsibling.nodeName);
</script>
</body>
</html>
Ejecución
Guarde este archivo como nextSibling_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). En la salida, obtenemos el siguiente nodo hermano de FirstName, es decir, LastName .
Hermano anterior
Esta propiedad es de tipo Node y representa el hijo anterior, es decir, el hermano anterior del elemento hijo especificado presente en NodeList.
Ejemplo
El siguiente ejemplo (previoussibling_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML, luego navega por el nodo anterior del último nodo secundario presente en el documento xml.
<!DOCTYPE html>
<body>
<script>
if (window.XMLHttpRequest)
{
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
function get_previousSibling(p) {
a = p.previousSibling;
while (a.nodeType != 1) {
a = a.previousSibling;
}
return a;
}
prevsibling = get_previousSibling(xmlDoc.getElementsByTagName("Email")[0]);
document.write(prevsibling.nodeName);
</script>
</body>
</html>
Ejecución
Guarde este archivo como previoussibling_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). En la salida, obtenemos el nodo hermano anterior de Correo electrónico, es decir, ContactNo .
En este capítulo estudiaremos cómo acceder a los nodos DOM XML que se consideran las unidades informativas del documento XML. La estructura de nodos del DOM XML permite al desarrollador navegar por el árbol en busca de información específica y acceder simultáneamente a la información.
Acceder a nodos
A continuación se muestran las tres formas en las que puede acceder a los nodos:
Usando el getElementsByTagName () método
Al recorrer o atravesar el árbol de nodos
Navegando por el árbol de nodos, usando las relaciones de nodos
getElementsByTagName ()
Este método permite acceder a la información de un nodo especificando el nombre del nodo. También permite acceder a la información de la Lista de Nodos y la Longitud de la Lista de Nodos.
Sintaxis
El método getElementByTagName () tiene la siguiente sintaxis:
node.getElementByTagName("tagname");
Dónde,
nodo : es el nodo del documento.
tagname : contiene el nombre del nodo cuyo valor desea obtener.
Ejemplo
A continuación se muestra un programa simple que ilustra el uso del método getElementByTagName.
<!DOCTYPE html>
<html>
<body>
<div>
<b>FirstName:</b> <span id = "FirstName"></span><br>
<b>LastName:</b> <span id = "LastName"></span><br>
<b>Category:</b> <span id = "Employee"></span><br>
</div>
<script>
if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp = new XMLHttpRequest();
} else {// code for IE6, IE5
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
document.getElementById("FirstName").innerHTML =
xmlDoc.getElementsByTagName("FirstName")[0].childNodes[0].nodeValue;
document.getElementById("LastName").innerHTML =
xmlDoc.getElementsByTagName("LastName")[0].childNodes[0].nodeValue;
document.getElementById("Employee").innerHTML =
xmlDoc.getElementsByTagName("Employee")[0].attributes[0].nodeValue;
</script>
</body>
</html>
En el ejemplo anterior, estamos accediendo a la información de los nodos FirstName , LastName y Employee .
xmlDoc.getElementsByTagName ("Nombre") [0] .childNodes [0] .nodeValue; Esta línea accede al valor del nodo hijo FirstName utilizando el método getElementByTagName ().
xmlDoc.getElementsByTagName ("Empleado") [0] .attributes [0] .nodeValue; Esta línea accede al valor de atributo del método de nodo Employee getElementByTagName ().
Atravesando nodos
Esto se trata en el capítulo Recorrido de DOM con ejemplos.
Navegando por los nodos
Esto se trata en el capítulo Navegación DOM con ejemplos.
En este capítulo, estudiaremos cómo obtener el valor de nodo de un objeto DOM XML. Los documentos XML tienen una jerarquía de unidades de información llamadas nodos. El objeto de nodo tiene una propiedad nodeValue , que devuelve el valor del elemento.
En las siguientes secciones, discutiremos:
Obtener el valor de nodo de un elemento
Obtener el valor de atributo de un nodo
El node.xml utilizado en todos los siguientes ejemplos es el siguiente:
<Company>
<Employee category = "Technical">
<FirstName>Tanmay</FirstName>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Non-Technical">
<FirstName>Taniya</FirstName>
<LastName>Mishra</LastName>
<ContactNo>1234667898</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Management">
<FirstName>Tanisha</FirstName>
<LastName>Sharma</LastName>
<ContactNo>1234562350</ContactNo>
<Email>[email protected]</Email>
</Employee>
</Company>
Obtener valor de nodo
El método getElementsByTagName () devuelve una NodeList de todos los Elementos en el orden del documento con un nombre de etiqueta determinado.
Ejemplo
El siguiente ejemplo (getnode_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y extrae el valor del nodo del nodo secundario Nombre (índice en 0):
<!DOCTYPE html>
<html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else{
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
x = xmlDoc.getElementsByTagName('FirstName')[0]
y = x.childNodes[0];
document.write(y.nodeValue);
</script>
</body>
</html>
Ejecución
Guarde este archivo como getnode_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). En la salida, obtenemos el valor del nodo como Tanmay .
Obtener valor de atributo
Los atributos son parte de los elementos del nodo XML. Un elemento de nodo puede tener múltiples atributos únicos. El atributo proporciona más información sobre los elementos del nodo XML. Para ser más precisos, definen las propiedades de los elementos del nodo. Un atributo XML es siempre un par nombre-valor. Este valor del atributo se denomina nodo de atributo .
El método getAttribute () recupera un valor de atributo por nombre de elemento.
Ejemplo
El siguiente ejemplo (get_attribute_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y extrae el valor del atributo de la categoría Empleado (índice en 2) -
<!DOCTYPE html>
<html>
<body>
<script>
if (window.XMLHttpRequest) {
xmlhttp = new XMLHttpRequest();
} else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","/dom/node.xml",false);
xmlhttp.send();
xmlDoc = xmlhttp.responseXML;
x = xmlDoc.getElementsByTagName('Employee')[2];
document.write(x.getAttribute('category'));
</script>
</body>
</html>
Ejecución
Guarde este archivo como get_attribute_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). En la salida, obtenemos el valor del atributo como Gestión .
En este capítulo, estudiaremos cómo cambiar los valores de los nodos en un objeto DOM XML. El valor del nodo se puede cambiar de la siguiente manera:
var value = node.nodeValue;
Si el nodo es un atributo , la variable de valor será el valor del atributo; si el nodo es un nodo de texto , será el contenido del texto; si el nodo es un elemento , será nulo .
Las siguientes secciones demostrarán la configuración del valor de nodo para cada tipo de nodo (atributo, nodo de texto y elemento).
El node.xml utilizado en todos los siguientes ejemplos es el siguiente:
<Company>
<Employee category = "Technical">
<FirstName>Tanmay</FirstName>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Non-Technical">
<FirstName>Taniya</FirstName>
<LastName>Mishra</LastName>
<ContactNo>1234667898</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Management">
<FirstName>Tanisha</FirstName>
<LastName>Sharma</LastName>
<ContactNo>1234562350</ContactNo>
<Email>[email protected]</Email>
</Employee>
</Company>
Cambiar el valor del nodo de texto
Cuando decimos el valor de cambio del elemento Node, nos referimos a editar el contenido de texto de un elemento (que también se llama nodo de texto ). El siguiente ejemplo demuestra cómo cambiar el nodo de texto de un elemento.
Ejemplo
El siguiente ejemplo (set_text_node_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y cambia el valor del nodo de texto de un elemento. En este caso, envíe un correo electrónico a cada empleado a [email protected] e imprima los valores.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName("Email");
for(i = 0;i<x.length;i++) {
x[i].childNodes[0].nodeValue = "[email protected]";
document.write(i+');
document.write(x[i].childNodes[0].nodeValue);
document.write('<br>');
}
</script>
</body>
</html>
Ejecución
Guarde este archivo como set_text_node_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). Recibirá el siguiente resultado:
0) [email protected]
1) [email protected]
2) [email protected]
Cambiar el valor del nodo de atributo
El siguiente ejemplo demuestra cómo cambiar el nodo de atributo de un elemento.
Ejemplo
El siguiente ejemplo (set_attribute_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y cambia el valor del nodo de atributo de un elemento. En este caso, la Categoría de cada Empleado para admin-0, admin-1, admin-2 respectivamente e imprima los valores.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName("Employee");
for(i = 0 ;i<x.length;i++){
newcategory = x[i].getAttributeNode('category');
newcategory.nodeValue = "admin-"+i;
document.write(i+');
document.write(x[i].getAttributeNode('category').nodeValue);
document.write('<br>');
}
</script>
</body>
</html>
Ejecución
Guarde este archivo como set_node_attribute_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). El resultado sería el siguiente:
0) admin-0
1) admin-1
2) admin-2
En este capítulo, discutiremos cómo crear nuevos nodos usando un par de métodos del objeto de documento. Estos métodos proporcionan un alcance para crear un nuevo nodo de elemento, nodo de texto, nodo de comentario, nodo de sección CDATA y nodo de atributo . Si el nodo recién creado ya existe en el objeto de elemento, se reemplaza por el nuevo. Las siguientes secciones demuestran esto con ejemplos.
Crear nuevo nodo de elemento
El método createElement () crea un nuevo elemento nodo. Si el nodo de elemento recién creado existe en el objeto de elemento, se reemplaza por el nuevo.
Sintaxis
La sintaxis para usar el método createElement () es la siguiente:
var_name = xmldoc.createElement("tagname");
Dónde,
var_name : es el nombre de la variable definida por el usuario que contiene el nombre del nuevo elemento.
("nombre de etiqueta") : es el nombre del nuevo nodo de elemento que se creará.
Ejemplo
El siguiente ejemplo (createnewelement_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y crea un nuevo nodo de elemento PhoneNo en el documento XML.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
new_element = xmlDoc.createElement("PhoneNo");
x = xmlDoc.getElementsByTagName("FirstName")[0];
x.appendChild(new_element);
document.write(x.getElementsByTagName("PhoneNo")[0].nodeName);
</script>
</body>
</html>
new_element = xmlDoc.createElement ("PhoneNo"); crea el nuevo nodo de elemento <PhoneNo>
x.appendChild (nuevo_elemento); x contiene el nombre del nodo secundario especificado <FirstName> al que se agrega el nuevo nodo de elemento.
Ejecución
Guarde este archivo como createnewelement_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). En la salida obtenemos el valor del atributo como PhoneNo .
Crear un nuevo nodo de texto
El método createTextNode () crea un nuevo nodo de texto.
Sintaxis
La sintaxis para usar createTextNode () es la siguiente:
var_name = xmldoc.createTextNode("tagname");
Dónde,
var_name : es el nombre de la variable definida por el usuario que contiene el nombre del nuevo nodo de texto.
("nombre de etiqueta") : entre paréntesis está el nombre del nuevo nodo de texto que se creará.
Ejemplo
El siguiente ejemplo (createtextnode_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y crea un nuevo nodo de texto Im nuevo nodo de texto en el documento XML.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
create_e = xmlDoc.createElement("PhoneNo");
create_t = xmlDoc.createTextNode("Im new text node");
create_e.appendChild(create_t);
x = xmlDoc.getElementsByTagName("Employee")[0];
x.appendChild(create_e);
document.write(" PhoneNO: ");
document.write(x.getElementsByTagName("PhoneNo")[0].childNodes[0].nodeValue);
</script>
</body>
</html>
Los detalles del código anterior son los siguientes:
create_e = xmlDoc.createElement ("PhoneNo"); crea un nuevo elemento < PhoneNo >.
create_t = xmlDoc.createTextNode ("Soy un nuevo nodo de texto"); crea un nuevo nodo de texto "Soy un nuevo nodo de texto" .
x.appendChild (crear_e); el nodo de texto, "Soy nuevo nodo de texto" se agrega al elemento, < PhoneNo >.
document.write (x.getElementsByTagName ("PhoneNo") [0] .childNodes [0] .nodeValue); escribe el nuevo valor del nodo de texto en el elemento <PhoneNo>.
Ejecución
Guarde este archivo como createtextnode_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). En la salida, obtenemos el valor del atributo como, por ejemplo, PhoneNO: Im new text node .
Crear nuevo nodo de comentario
El método createComment () crea un nuevo nodo de comentario. El nodo de comentario está incluido en el programa para una fácil comprensión de la funcionalidad del código.
Sintaxis
La sintaxis para usar createComment () es la siguiente:
var_name = xmldoc.createComment("tagname");
Dónde,
var_name : es el nombre de la variable definida por el usuario que contiene el nombre del nuevo nodo de comentario.
("nombre de etiqueta") : es el nombre del nuevo nodo de comentario que se creará.
Ejemplo
El siguiente ejemplo (createcommentnode_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y crea un nuevo nodo de comentario, "La empresa es el nodo principal" en el documento XML.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
}
else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
create_comment = xmlDoc.createComment("Company is the parent node");
x = xmlDoc.getElementsByTagName("Company")[0];
x.appendChild(create_comment);
document.write(x.lastChild.nodeValue);
</script>
</body>
</html>
En el ejemplo anterior:
create_comment = xmlDoc.createComment ("La empresa es el nodo principal") creates a specified comment line.
x.appendChild (create_comment) En esta línea, 'x' contiene el nombre del elemento <Company> al que se agrega la línea de comentarios.
Ejecución
Guarde este archivo como createcommentnode_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). En la salida, obtenemos el valor del atributo ya que Company es el nodo principal .
Crear nuevo nodo de sección CDATA
El método createCDATASection () crea un nuevo nodo de sección CDATA. Si el nodo de la sección CDATA recién creado existe en el objeto de elemento, se reemplaza por el nuevo.
Sintaxis
La sintaxis para usar createCDATASection () es la siguiente:
var_name = xmldoc.createCDATASection("tagname");
Dónde,
var_name : es el nombre de la variable definida por el usuario que contiene el nombre del nuevo nodo de la sección CDATA.
("nombre de etiqueta") : es el nombre del nuevo nodo de la sección CDATA que se creará.
Ejemplo
El siguiente ejemplo (createcdatanode_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y crea un nuevo nodo de sección CDATA, "Crear ejemplo CDATA" en el documento XML.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
}
else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
create_CDATA = xmlDoc.createCDATASection("Create CDATA Example");
x = xmlDoc.getElementsByTagName("Employee")[0];
x.appendChild(create_CDATA);
document.write(x.lastChild.nodeValue);
</script>
</body>
</html>
En el ejemplo anterior:
create_CDATA = xmlDoc.createCDATASection ("Crear ejemplo de CDATA") crea un nuevo nodo de sección CDATA, "Crear ejemplo de CDATA"
x.appendChild (create_CDATA) aquí, x contiene el elemento especificado <Employee> indexado en 0 al que se agrega el valor del nodo CDATA.
Ejecución
Guarde este archivo como createcdatanode_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). En la salida, obtenemos el valor del atributo como Crear ejemplo CDATA .
Crear un nuevo nodo de atributo
Para crear un nuevo nodo de atributo, se utiliza el método setAttributeNode () . Si el nodo de atributo recién creado existe en el objeto de elemento, se reemplaza por el nuevo.
Sintaxis
La sintaxis para usar el método createElement () es la siguiente:
var_name = xmldoc.createAttribute("tagname");
Dónde,
var_name : es el nombre de la variable definida por el usuario que contiene el nombre del nuevo nodo de atributo.
("nombre de etiqueta") : es el nombre del nuevo nodo de atributo que se creará.
Ejemplo
El siguiente ejemplo (createattributenode_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y crea una nueva sección de nodo de atributo en el documento XML.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
create_a = xmlDoc.createAttribute("section");
create_a.nodeValue = "A";
x = xmlDoc.getElementsByTagName("Employee");
x[0].setAttributeNode(create_a);
document.write("New Attribute: ");
document.write(x[0].getAttribute("section"));
</script>
</body>
</html>
En el ejemplo anterior:
create_a = xmlDoc.createAttribute ("Categoría") crea un atributo con el nombre <sección>.
create_a.nodeValue = "Gestión" crea el valor "A" para el atributo <sección>.
x [0] .setAttributeNode (create_a) este valor de atributo se establece en el elemento de nodo <Employee> indexado en 0.
En este capítulo, discutiremos los nodos del elemento existente. Proporciona un medio para:
agregar nuevos nodos secundarios antes o después de los nodos secundarios existentes
insertar datos dentro del nodo de texto
agregar nodo de atributo
Los siguientes métodos se pueden usar para agregar / adjuntar los nodos a un elemento en un DOM:
- appendChild()
- insertBefore()
- insertData()
añadir Niño()
El método appendChild () agrega el nuevo nodo secundario después del nodo secundario existente.
Sintaxis
La sintaxis del método appendChild () es la siguiente:
Node appendChild(Node newChild) throws DOMException
Dónde,
newChild : es el nodo a agregar
Este método devuelve el nodo agregado.
Ejemplo
El siguiente ejemplo (appendchildnode_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y agrega un nuevo PhoneNo secundario al elemento <FirstName>.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
create_e = xmlDoc.createElement("PhoneNo");
x = xmlDoc.getElementsByTagName("FirstName")[0];
x.appendChild(create_e);
document.write(x.getElementsByTagName("PhoneNo")[0].nodeName);
</script>
</body>
</html>
En el ejemplo anterior:
utilizando el método createElement (), se crea un nuevo elemento PhoneNo .
El nuevo elemento PhoneNo se agrega al elemento FirstName usando el método appendChild ().
Ejecución
Guarde este archivo como appendchildnode_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). En la salida, obtenemos el valor del atributo como PhoneNo .
insertBefore ()
El método insertBefore () , inserta los nuevos nodos secundarios antes que los nodos secundarios especificados.
Sintaxis
La sintaxis del método insertBefore () es la siguiente:
Node insertBefore(Node newChild, Node refChild) throws DOMException
Dónde,
newChild : es el nodo que se va a insertar
refChild : es el nodo de referencia, es decir, el nodo antes del cual se debe insertar el nuevo nodo.
Este método devuelve el nodo que se está insertando.
Ejemplo
El siguiente ejemplo (insertnodebefore_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML e inserta un nuevo correo electrónico secundario antes del elemento especificado <Email>.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
create_e = xmlDoc.createElement("Email");
x = xmlDoc.documentElement;
y = xmlDoc.getElementsByTagName("Email");
document.write("No of Email elements before inserting was: " + y.length);
document.write("<br>");
x.insertBefore(create_e,y[3]);
y=xmlDoc.getElementsByTagName("Email");
document.write("No of Email elements after inserting is: " + y.length);
</script>
</body>
</html>
En el ejemplo anterior:
utilizando el método createElement (), se crea un nuevo elemento Email .
El nuevo elemento Correo electrónico se agrega antes del elemento Correo electrónico utilizando el método insertBefore ().
y.length da el número total de elementos agregados antes y después del nuevo elemento.
Ejecución
Guarde este archivo como insertnodebefore_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). Recibiremos el siguiente resultado:
No of Email elements before inserting was: 3
No of Email elements after inserting is: 4
insertData ()
El método insertData () inserta una cadena en el desplazamiento de unidad de 16 bits especificado.
Sintaxis
InsertData () tiene la siguiente sintaxis:
void insertData(int offset, java.lang.String arg) throws DOMException
Dónde,
desplazamiento : es el desplazamiento de caracteres en el que se inserta.
arg : es la palabra clave para insertar los datos. Incluye los dos parámetros offset y string entre paréntesis separados por comas.
Ejemplo
El siguiente ejemplo (addtext_example.htm) analiza un documento XML (" node.xml ") en un objeto DOM XML e inserta nuevos datos MiddleName en la posición especificada en el elemento <FirstName>.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName("FirstName")[0].childNodes[0];
document.write(x.nodeValue);
x.insertData(6,"MiddleName");
document.write("<br>");
document.write(x.nodeValue);
</script>
</body>
</html>
x.insertData(6,"MiddleName");- Aquí, x contiene el nombre del niño especificado, es decir, <FirstName>. Luego insertamos en este nodo de texto los datos "MiddleName" comenzando desde la posición 6.
Ejecución
Guarde este archivo como addtext_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). Recibiremos lo siguiente en la salida:
Tanmay
TanmayMiddleName
En este capítulo, estudiaremos sobre la operación de reemplazo de nodo en un objeto DOM XML. Como sabemos, todo en el DOM se mantiene en una unidad de información jerárquica conocida como nodo y el nodo de reemplazo proporciona otra forma de actualizar estos nodos especificados o un nodo de texto.
A continuación se muestran los dos métodos para reemplazar los nodos.
- replaceChild()
- replaceData()
replaceChild ()
El método replaceChild () reemplaza el nodo especificado con el nuevo nodo.
Sintaxis
InsertData () tiene la siguiente sintaxis:
Node replaceChild(Node newChild, Node oldChild) throws DOMException
Dónde,
newChild : es el nuevo nodo que se coloca en la lista de niños.
oldChild : es el nodo que se reemplaza en la lista.
Este método devuelve el nodo reemplazado.
Ejemplo
El siguiente ejemplo (replacenode_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y reemplaza el nodo especificado <FirstName> con el nuevo nodo <Name>.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.documentElement;
z = xmlDoc.getElementsByTagName("FirstName");
document.write("<b>Content of FirstName element before replace operation</b><br>");
for (i=0;i<z.length;i++) {
document.write(z[i].childNodes[0].nodeValue);
document.write("<br>");
}
//create a Employee element, FirstName element and a text node
newNode = xmlDoc.createElement("Employee");
newTitle = xmlDoc.createElement("Name");
newText = xmlDoc.createTextNode("MS Dhoni");
//add the text node to the title node,
newTitle.appendChild(newText);
//add the title node to the book node
newNode.appendChild(newTitle);
y = xmlDoc.getElementsByTagName("Employee")[0]
//replace the first book node with the new node
x.replaceChild(newNode,y);
z = xmlDoc.getElementsByTagName("FirstName");
document.write("<b>Content of FirstName element after replace operation</b><br>");
for (i = 0;i<z.length;i++) {
document.write(z[i].childNodes[0].nodeValue);
document.write("<br>");
}
</script>
</body>
</html>
Ejecución
Guarde este archivo como replacenode_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). Obtendremos el resultado como se muestra a continuación:
Content of FirstName element before replace operation
Tanmay
Taniya
Tanisha
Content of FirstName element after replace operation
Taniya
Tanisha
replaceData ()
El método replaceData () reemplaza los caracteres que comienzan en el desplazamiento de unidad de 16 bits especificado con la cadena especificada.
Sintaxis
El replaceData () tiene la siguiente sintaxis:
void replaceData(int offset, int count, java.lang.String arg) throws DOMException
Dónde
desplazamiento : es el desplazamiento desde el cual comenzar a reemplazar.
recuento : es el número de unidades de 16 bits que se deben reemplazar. Si la suma del desplazamiento y el recuento excede la longitud, se reemplazan todas las unidades de 16 bits hasta el final de los datos.
arg : DOMString con el que se debe reemplazar el rango.
Ejemplo
El siguiente ejemplo (replacedata_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y lo reemplaza.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName("ContactNo")[0].childNodes[0];
document.write("<b>ContactNo before replace operation:</b> "+x.nodeValue);
x.replaceData(1,5,"9999999");
document.write("<br>");
document.write("<b>ContactNo after replace operation:</b> "+x.nodeValue);
</script>
</body>
</html>
En el ejemplo anterior:
x.replaceData (2,3, "999"); - Aquí x contiene el texto del elemento especificado <ContactNo> cuyo texto se reemplaza por el nuevo texto "9999999" , comenzando desde la posición 1 hasta la longitud de 5 .
Ejecución
Guarde este archivo como replacedata_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). Obtendremos el resultado como se muestra a continuación:
ContactNo before replace operation: 1234567890
ContactNo after replace operation: 199999997890
En este capítulo, estudiaremos la operación XML DOM Remove Node . La operación de eliminación de nodo elimina el nodo especificado del documento. Esta operación se puede implementar para eliminar los nodos como un nodo de texto, un nodo de elemento o un nodo de atributo.
Los siguientes son los métodos que se utilizan para eliminar la operación de nodo:
removeChild()
removeAttribute()
removeChild ()
El método removeChild () elimina el nodo hijo indicado por oldChild de la lista de hijos y lo devuelve. Eliminar un nodo hijo equivale a eliminar un nodo de texto. Por lo tanto, la eliminación de un nodo secundario elimina el nodo de texto asociado a él.
Sintaxis
La sintaxis para usar removeChild () es la siguiente:
Node removeChild(Node oldChild) throws DOMException
Dónde,
oldChild : es el nodo que se está eliminando.
Este método devuelve el nodo eliminado.
Ejemplo: eliminar nodo actual
El siguiente ejemplo (removecurrentnode_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y elimina el nodo especificado <ContactNo> del nodo principal.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
document.write("<b>Before remove operation, total ContactNo elements: </b>");
document.write(xmlDoc.getElementsByTagName("ContactNo").length);
document.write("<br>");
x = xmlDoc.getElementsByTagName("ContactNo")[0];
x.parentNode.removeChild(x);
document.write("<b>After remove operation, total ContactNo elements: </b>");
document.write(xmlDoc.getElementsByTagName("ContactNo").length);
</script>
</body>
</html>
En el ejemplo anterior:
x = xmlDoc.getElementsByTagName ("ContactNo") [0] obtiene el elemento <ContactNo> indexado en 0.
x.parentNode.removeChild (x); elimina el elemento <ContactNo> indexado en 0 del nodo principal.
Ejecución
Guarde este archivo como removecurrentnode_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). Obtenemos el siguiente resultado:
Before remove operation, total ContactNo elements: 3
After remove operation, total ContactNo elements: 2
Ejemplo: eliminar nodo de texto
El siguiente ejemplo (removetextNode_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y elimina el nodo secundario especificado <FirstName>.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName("FirstName")[0];
document.write("<b>Text node of child node before removal is:</b> ");
document.write(x.childNodes.length);
document.write("<br>");
y = x.childNodes[0];
x.removeChild(y);
document.write("<b>Text node of child node after removal is:</b> ");
document.write(x.childNodes.length);
</script>
</body>
</html>
En el ejemplo anterior:
x = xmlDoc.getElementsByTagName ("Nombre") [0]; - obtiene el primer elemento <FirstName> a la x indexada en 0.
y = x.childNodes [0]; - en esta línea y contiene el nodo hijo que se va a eliminar.
x.removeChild (y); : Elimina el nodo hijo especificado.
Ejecución
Guarde este archivo como removetextNode_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). Obtenemos el siguiente resultado:
Text node of child node before removal is: 1
Text node of child node after removal is: 0
removeAttribute ()
El método removeAttribute () elimina un atributo de un elemento por su nombre.
Sintaxis
La sintaxis para usar removeAttribute () es la siguiente:
void removeAttribute(java.lang.String name) throws DOMException
Dónde,
nombre : es el nombre del atributo que se va a eliminar.
Ejemplo
El siguiente ejemplo (removeelementattribute_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y elimina el nodo de atributo especificado.
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName('Employee');
document.write(x[1].getAttribute('category'));
document.write("<br>");
x[1].removeAttribute('category');
document.write(x[1].getAttribute('category'));
</script>
</body>
</html>
En el ejemplo anterior:
document.write (x [1] .getAttribute ('categoría')); - se invoca el valor de la categoría de atributo indexada en la 1ª posición.
x [1] .removeAttribute ('categoría'); : Elimina el valor del atributo.
Ejecución
Guarde este archivo como removeelementattribute_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). Obtenemos el siguiente resultado:
Non-Technical
null
En este capítulo, analizaremos la operación de clonar nodo en un objeto DOM XML. La operación de clonar nodo se utiliza para crear una copia duplicada del nodo especificado. cloneNode () se utiliza para esta operación.
cloneNode ()
Este método devuelve un duplicado de este nodo, es decir, sirve como un constructor de copia genérico para los nodos. El nodo duplicado no tiene padre (parentNode es nulo) ni datos de usuario.
Sintaxis
El método cloneNode () tiene la siguiente sintaxis:
Node cloneNode(boolean deep)
deep : si es verdadero, clona recursivamente el subárbol bajo el nodo especificado; si es falso, clone solo el nodo en sí (y sus atributos, si es un Elemento).
Este método devuelve el nodo duplicado.
Ejemplo
El siguiente ejemplo (clonenode_example.htm) analiza un documento XML ( node.xml ) en un objeto DOM XML y crea una copia en profundidad del primer elemento Employee .
<!DOCTYPE html>
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
xmlDoc = loadXMLDoc("/dom/node.xml");
x = xmlDoc.getElementsByTagName('Employee')[0];
clone_node = x.cloneNode(true);
xmlDoc.documentElement.appendChild(clone_node);
firstname = xmlDoc.getElementsByTagName("FirstName");
lastname = xmlDoc.getElementsByTagName("LastName");
contact = xmlDoc.getElementsByTagName("ContactNo");
email = xmlDoc.getElementsByTagName("Email");
for (i = 0;i < firstname.length;i++) {
document.write(firstname[i].childNodes[0].nodeValue+'
'+lastname[i].childNodes[0].nodeValue+',
'+contact[i].childNodes[0].nodeValue+', '+email[i].childNodes[0].nodeValue);
document.write("<br>");
}
</script>
</body>
</html>
Como puede ver en el ejemplo anterior, hemos establecido el parámetro cloneNode () en verdadero . Por lo tanto, cada uno de los elementos secundarios del elemento Empleado se copia o clona.
Ejecución
Guarde este archivo como clonenode_example.htm en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). Obtendremos el resultado como se muestra a continuación:
Tanmay Patil, 1234567890, [email protected]
Taniya Mishra, 1234667898, [email protected]
Tanisha Sharma, 1234562350, [email protected]
Tanmay Patil, 1234567890, [email protected]
Notará que el primer elemento Empleado se clona por completo.
La interfaz de nodo es el tipo de datos principal para todo el modelo de objetos de documento. El nodo se utiliza para representar un solo elemento XML en todo el árbol del documento.
Un nodo puede ser de cualquier tipo que sea un nodo de atributo, un nodo de texto o cualquier otro nodo. Los atributos nodeName, nodeValue y los atributos se incluyen como un mecanismo para obtener información sobre el nodo sin necesidad de pasar a la interfaz derivada específica.
Atributos
La siguiente tabla enumera los atributos del objeto Node :
Atributo | Tipo | Descripción |
---|---|---|
atributos | NamedNodeMap | Es de tipo NamedNodeMap que contiene los atributos de este nodo (si es un elemento) o nulo en caso contrario. Esto ha sido eliminado. Consulte especificaciones |
baseURI | DOMString | Se utiliza para especificar el URI base absoluto del nodo. |
childNodes | NodeList | Es una NodeList que contiene todos los elementos secundarios de este nodo. Si no hay hijos, esta es una NodeList que no contiene nodos. |
primer hijo | Nodo | Especifica el primer hijo de un nodo. |
último niño | Nodo | Especifica el último hijo de un nodo. |
nombre local | DOMString | Se utiliza para especificar el nombre de la parte local de un nodo. Esto ha sido eliminado. Consulte las especificaciones . |
espacio de nombresURI | DOMString | Especifica el URI del espacio de nombres de un nodo. Esto ha sido eliminado. Consulte especificaciones |
proximo hermano | Nodo | Devuelve el nodo inmediatamente siguiente a este nodo. Si no existe tal nodo, esto devuelve nulo. |
nombre del nodo | DOMString | El nombre de este nodo, según su tipo. |
nodeType | corto sin firmar | Es un código que representa el tipo de objeto subyacente. |
nodeValue | DOMString | Se utiliza para especificar el valor de un nodo en función de sus tipos. |
ownerDocument | Documento | Especifica el objeto Documento asociado con el nodo. |
parentNode | Nodo | Esta propiedad especifica el nodo padre de un nodo. |
prefijo | DOMString | Esta propiedad devuelve el prefijo de espacio de nombres de un nodo. Esto ha sido eliminado. Consulte especificaciones |
anteriorHermano | Nodo | Esto especifica el nodo inmediatamente anterior al nodo actual. |
contenido del texto | DOMString | Esto especifica el contenido textual de un nodo. |
Tipos de nodo
Hemos enumerado los tipos de nodos a continuación:
- ELEMENT_NODE
- ATTRIBUTE_NODE
- ENTITY_NODE
- ENTITY_REFERENCE_NODE
- DOCUMENT_FRAGMENT_NODE
- TEXT_NODE
- CDATA_SECTION_NODE
- COMMENT_NODE
- PROCESSING_INSTRUCTION_NODE
- DOCUMENT_NODE
- DOCUMENT_TYPE_NODE
- NOTATION_NODE
Métodos
La siguiente tabla enumera los diferentes métodos de objetos de nodo:
S.No. | Método y descripción |
---|---|
1 | appendChild (nodo newChild) Este método agrega un nodo después del último nodo hijo del nodo de elemento especificado. Devuelve el nodo agregado. |
2 | cloneNode (booleano profundo) Este método se utiliza para crear un nodo duplicado, cuando se reemplaza en una clase derivada. Devuelve el nodo duplicado. |
3 | compareDocumentPosition (otro nodo) Este método se utiliza para comparar la posición del nodo actual con un nodo especificado de acuerdo con el orden del documento. Devuelve unsigned short , cómo se posiciona el nodo en relación con el nodo de referencia. |
4 | getFeature(DOMString feature, DOMString version) Devuelve el objeto DOM que implementa las API especializadas de la función y versión especificadas, si las hay, o nula si no hay ningún objeto. Esto ha sido eliminado. Consulte las especificaciones . |
5 | getUserData(DOMString key) Recupera el objeto asociado a una clave en este nodo. El objeto primero debe haberse establecido en este nodo llamando al setUserData con la misma clave. Devuelve DOMUserData asociado a la clave dada en este nodo, o nulo si no había ninguno. Esto ha sido eliminado. Consulte las especificaciones . |
6 | hasAttributes() Devuelve si este nodo (si es un elemento) tiene algún atributo o no. Devuelve verdadero si hay algún atributo presente en el nodo especificado; de lo contrario, devuelve falso . Esto ha sido eliminado. Consulte las especificaciones . |
7 | hasChildNodes () Devuelve si este nodo tiene hijos. Este método devuelve verdadero si el nodo actual tiene nodos secundarios; de lo contrario, es falso . |
8 | insertBefore (nodo newChild, nodo refChild) Este método se utiliza para insertar un nuevo nodo como hijo de este nodo, directamente antes de un hijo existente de este nodo. Devuelve el nodo que se está insertando. |
9 | isDefaultNamespace (DOMString namespaceURI) Este método acepta un URI de espacio de nombres como argumento y devuelve un valor booleano con un valor verdadero si el espacio de nombres es el espacio de nombres predeterminado en el nodo dado o falso en caso contrario. |
10 | isEqualNode (nodo arg) Este método prueba si dos nodos son iguales. Devuelve verdadero si los nodos son iguales, falso en caso contrario. |
11 | isSameNode(Node other) Este método devuelve si el nodo actual es el mismo nodo que el dado. Devuelve verdadero si los nodos son iguales, falso en caso contrario. Esto ha sido eliminado. Consulte las especificaciones . |
12 | isSupported(DOMString feature, DOMString version) Este método devuelve si el módulo DOM especificado es compatible con el nodo actual. Devuelve verdadero si la característica especificada es compatible con este nodo, falso en caso contrario. Esto ha sido eliminado. Consulte las especificaciones . |
13 | lookupNamespaceURI (prefijo DOMString) Este método obtiene el URI del espacio de nombres asociado con el prefijo del espacio de nombres. |
14 | lookupPrefix (DOMString namespaceURI) Este método devuelve el prefijo más cercano definido en el espacio de nombres actual para el URI del espacio de nombres. Devuelve un prefijo de espacio de nombres asociado si se encuentra o nulo si no se encuentra ninguno. |
15 | normalizar() La normalización agrega todos los nodos de texto, incluidos los nodos de atributos que definen una forma normal donde la estructura de los nodos que contienen elementos, comentarios, instrucciones de procesamiento, secciones CDATA y referencias de entidades separa los nodos de texto, es decir, ni los nodos de texto adyacentes ni los nodos de texto vacíos. |
dieciséis | removeChild (nodo oldChild) Este método se utiliza para eliminar un nodo hijo especificado del nodo actual. Esto devuelve el nodo eliminado. |
17 | replaceChild (Node newChild, Node oldChild) Este método se utiliza para reemplazar el antiguo nodo hijo por un nuevo nodo. Esto devuelve el nodo reemplazado. |
18 | setUserData(DOMString key, DOMUserData data, UserDataHandler handler) Este método asocia un objeto a una clave en este nodo. El objeto se puede recuperar posteriormente de este nodo llamando a getUserData con la misma clave. Esto devuelve DOMUserData previamente asociado a la clave dada en este nodo. Esto ha sido eliminado. Consulte las especificaciones . |
El objeto NodeList especifica la abstracción de una colección ordenada de nodos. Se puede acceder a los elementos de NodeList mediante un índice integral, comenzando desde 0.
Atributos
La siguiente tabla enumera los atributos del objeto NodeList:
Atributo | Tipo | Descripción |
---|---|---|
longitud | largo sin firmar | Da el número de nodos en la lista de nodos. |
Métodos
El siguiente es el único método del objeto NodeList.
S.No. | Método y descripción |
---|---|
1 | articulo() Devuelve el elemento de índice de la colección. Si el índice es mayor o igual que el número de nodos de la lista, devuelve nulo. |
El objeto NamedNodeMap se utiliza para representar colecciones de nodos a los que se puede acceder por su nombre.
Atributos
La siguiente tabla enumera la propiedad del objeto NamedNodeMap.
Atributo | Tipo | Descripción |
---|---|---|
longitud | largo sin firmar | Da el número de nodos en este mapa. El rango de índices de nodo hijo válidos es de 0 a 1 de longitud inclusive. |
Métodos
La siguiente tabla enumera los métodos del objeto NamedNodeMap .
S.No. | Métodos y descripción |
---|---|
1 | getNamedItem () Recupera el nodo especificado por nombre. |
2 | getNamedItemNS () Recupera un nodo especificado por nombre local y URI de espacio de nombres. |
3 | articulo () Devuelve el elemento de índice en el mapa. Si el índice es mayor o igual que el número de nodos en este mapa, esto devuelve nulo. |
4 | removeNamedItem () Elimina un nodo especificado por su nombre. |
5 | removeNamedItemNS () Elimina un nodo especificado por el nombre local y el URI del espacio de nombres. |
6 | setNamedItem () Agrega un nodo usando su atributo nodeName . Si un nodo con ese nombre ya está presente en este mapa, se reemplaza por el nuevo. |
7 | setNamedItemNS () Agrega un nodo usando su namespaceURI y localName . Si un nodo con ese URI de espacio de nombres y ese nombre local ya está presente en este mapa, se reemplaza por el nuevo. Reemplazar un nodo por sí solo no tiene ningún efecto. |
El objeto DOMImplementation proporciona una serie de métodos para realizar operaciones que son independientes de cualquier instancia particular del modelo de objeto de documento.
Métodos
La siguiente tabla enumera los métodos del objeto DOMImplementation :
S.No. | Método y descripción |
---|---|
1 | createDocument(namespaceURI, qualifiedName, doctype) It creates a DOM Document object of the specified type with its document element. |
2 | createDocumentType(qualifiedName, publicId, systemId) It creates an empty DocumentType node. |
3 | getFeature(feature, version) This method returns a specialized object which implements the specialized APIs of the specified feature and version. This has been removed. Refer specs. |
4 | hasFeature(feature, version) This method tests if the DOM implementation implements a specific feature and version. |
The DocumentType objects are the key to access the document's data and in the document, the doctype attribute can have either the null value or the DocumentType Object value. These DocumentType objects act as an interface to the entities described for an XML document.
Attributes
The following table lists the attributes of the DocumentType object −
Attribute | Type | Description |
---|---|---|
name | DOMString | It returns the name of the DTD which is written immediately next to the keyword !DOCTYPE. |
entities | NamedNodeMap | It returns a NamedNodeMap object containing the general entities, both external and internal, declared in the DTD. |
notations | NamedNodeMap | It returns a NamedNodeMap containing the notations declared in the DTD. |
internalSubset | DOMString | It returns an internal subset as a string, or null if there is none. This has been removed. Refer specs. |
publicId | DOMString | It returns the public identifier of the external subset. |
systemId | DOMString | It returns the system identifier of the external subset. This may be an absolute URI or not. |
Methods
DocumentType inherits methods from its parent, Node, and implements the ChildNode interface.
ProcessingInstruction gives that application-specific information which is generally included in the prolog section of the XML document.
Las instrucciones de procesamiento (PI) se pueden utilizar para pasar información a las aplicaciones. Los PI pueden aparecer en cualquier parte del documento fuera del marcado. Pueden aparecer en el prólogo, incluida la definición del tipo de documento (DTD), en el contenido textual o después del documento.
Un PI comienza con una etiqueta especial <? y termina con ?>. El procesamiento del contenido finaliza inmediatamente después de la cadena.?> se encuentra.
Atributos
La siguiente tabla enumera los atributos del objeto ProcessingInstruction :
Atributo | Tipo | Descripción |
---|---|---|
datos | DOMString | Es un carácter que describe la información que debe procesar la aplicación inmediatamente antes de?>. |
objetivo | DOMString | Esto identifica la aplicación a la que se dirigen la instrucción o los datos. |
La interfaz de entidad representa una entidad conocida, analizada o no analizada, en un documento XML. El atributo nodeName que se hereda de Node contiene el nombre de la entidad.
Un objeto Entity no tiene ningún nodo padre y todos sus nodos sucesores son de solo lectura.
Atributos
La siguiente tabla enumera los atributos del objeto Entity :
Atributo | Tipo | Descripción |
---|---|---|
inputEncoding | DOMString | Esto especifica la codificación utilizada por la entidad analizada externa. Su valor es nulo si es una entidad del subconjunto interno o si no se conoce. |
notationName | DOMString | Para las entidades sin analizar, da el nombre de la notación y su valor es nulo para las entidades analizadas. |
publicId | DOMString | Da el nombre del identificador público asociado a la entidad. |
systemId | DOMString | Da el nombre del identificador del sistema asociado con la entidad. |
xmlEncoding | DOMString | Proporciona la codificación xml incluida como parte de la declaración de texto para la entidad analizada externa, nula en caso contrario. |
xmlVersion | DOMString | Proporciona la versión xml incluida como parte de la declaración de texto para la entidad analizada externa, nula en caso contrario. |
Los objetos EntityReference son las referencias de entidad general que se insertan en el documento XML proporcionando el alcance para reemplazar el texto. El objeto EntityReference no funciona para las entidades predefinidas, ya que el HTML o el procesador XML las considera expandidas.
Esta interfaz no tiene propiedades ni métodos propios, pero hereda de Node .
En este capítulo, estudiaremos sobre el objeto XML DOM Notation . La propiedad del objeto de notación proporciona un alcance para reconocer el formato de los elementos con un atributo de notación, una instrucción de procesamiento particular o datos que no son XML. Las propiedades y los métodos del objeto de nodo se pueden realizar en el objeto de notación, ya que también se considera como un objeto de nodo.
Este objeto hereda métodos y propiedades de Node . Su nodeName es el nombre de la notación. No tiene padre.
Atributos
La siguiente tabla enumera los atributos del objeto de notación :
Atributo | Tipo | Descripción |
---|---|---|
publicID | DOMString | Da el nombre del identificador público asociado con la notación. |
systemID | DOMString | Da el nombre del identificador del sistema asociado con la notación. |
Los elementos XML se pueden definir como bloques de construcción de XML. Los elementos pueden comportarse como contenedores para contener texto, elementos, atributos, objetos multimedia o todos estos. Siempre que el analizador analiza un documento XML con el formato correcto, el analizador navega a través de un nodo de elemento. Un nodo de elemento contiene el texto dentro de él que se llama como el nodo de texto.
El objeto elemento hereda las propiedades y los métodos del objeto Nodo, ya que el objeto elemento también se considera como un Nodo. Aparte de las propiedades y métodos del objeto de nodo, tiene las siguientes propiedades y métodos.
Propiedades
La siguiente tabla enumera los atributos del objeto Elemento :
Atributo | Tipo | Descripción |
---|---|---|
tagName | DOMString | Da el nombre de la etiqueta para el elemento especificado. |
schemaTypeInfo | TypeInfo | Representa la información de tipo asociada con este elemento. Esto ha sido eliminado. Consulte las especificaciones . |
Métodos
La siguiente tabla enumera los métodos de objeto de elemento:
Métodos | Tipo | Descripción |
---|---|---|
getAttribute () | DOMString | Recupera el valor del atributo si existe para el elemento especificado. |
getAttributeNS () | DOMString | Recupera un valor de atributo por nombre local y URI de espacio de nombres. |
getAttributeNode () | Attr | Recupera el nombre del nodo de atributo del elemento actual. |
getAttributeNodeNS () | Attr | Recupera un nodo Attr por nombre local y URI de espacio de nombres. |
getElementsByTagName () | NodeList | Devuelve una NodeList de todos los elementos descendientes con un nombre de etiqueta determinado, en el orden del documento. |
getElementsByTagNameNS () | NodeList | Devuelve una NodeList de todos los elementos descendientes con un nombre local y un URI de espacio de nombres dados en el orden del documento. |
hasAttribute () | booleano | Devuelve verdadero cuando un atributo con un nombre dado se especifica en este elemento o tiene un valor predeterminado, falso en caso contrario. |
hasAttributeNS () | booleano | Devuelve verdadero cuando un atributo con un nombre local y un URI de espacio de nombres dados se especifica en este elemento o tiene un valor predeterminado; de lo contrario, es falso. |
removeAttribute () | Sin valor devuelto | Elimina un atributo por nombre. |
removeAttributeNS | Sin valor devuelto | Elimina un atributo por nombre local y URI de espacio de nombres. |
removeAttributeNode () | Attr | El nodo de atributo especificado se elimina del elemento. |
setAttribute () | Sin valor devuelto | Establece un nuevo valor de atributo para el elemento existente. |
setAttributeNS () | Sin valor devuelto | Agrega un nuevo atributo. Si un atributo con el mismo nombre local y URI de espacio de nombres ya está presente en el elemento, su prefijo se cambia para que sea la parte del prefijo del nombre calificado y su valor se cambia para ser el parámetro de valor. |
setAttributeNode () | Attr | Establece un nuevo nodo de atributo para el elemento existente. |
setAttributeNodeNS | Attr | Agrega un nuevo atributo. Si un atributo con ese nombre local y ese URI de espacio de nombres ya está presente en el elemento, se reemplaza por el nuevo. |
setIdAttribute | Sin valor devuelto | Si el parámetro isId es verdadero, este método declara que el atributo especificado es un atributo de ID determinado por el usuario. Esto ha sido eliminado. Consulte las especificaciones . |
setIdAttributeNS | Sin valor devuelto | Si el parámetro isId es verdadero, este método declara que el atributo especificado es un atributo de ID determinado por el usuario. Esto ha sido eliminado. Consulte las especificaciones . |
La interfaz Attr representa un atributo en un objeto Element. Normalmente, los valores permitidos para el atributo se definen en un esquema asociado con el documento. Los objetos Attr no se consideran parte del árbol del documento, ya que en realidad no son nodos secundarios del elemento que describen. Por lo tanto, para los nodos secundarios parentNode , previousSibling y nextSibling, el valor del atributo es nulo .
Atributos
La siguiente tabla enumera los atributos del objeto Attribute :
Atributo | Tipo | Descripción |
---|---|---|
nombre | DOMString | Esto le da el nombre del atributo. |
especificado | booleano | Es un valor booleano que devuelve verdadero si el valor del atributo existe en el documento. |
valor | DOMString | Devuelve el valor del atributo. |
ownerElement | Elemento | Da el nodo al cual el atributo está asociado o es nulo si el atributo no está en uso. |
isId | booleano | Devuelve si se sabe que el atributo es de tipo ID (es decir, que contiene un identificador para su elemento propietario) o no. |
En este capítulo, estudiaremos sobre XML DOM CDATASection Object . El texto presente dentro de un documento XML se analiza o no se analiza según lo que se declare. Si el texto se declara como Parse Character Data (PCDATA), el analizador lo analiza para convertir un documento XML en un objeto DOM XML. Por otro lado, si el texto se declara como Datos de caracteres sin analizar (CDATA), el analizador XML no analiza el texto que contiene. Estos no se consideran como el marcado y no expandirán las entidades.
El propósito de utilizar el objeto CDATASection es escapar de los bloques de texto que contienen caracteres que, de otro modo, se considerarían marcas. "]]>", este es el único delimitador reconocido en una sección CDATA que finaliza la sección CDATA.
El atributo CharacterData.data contiene el texto que contiene la sección CDATA. Esta interfaz hereda la interfaz CharatcterData a través de la interfaz Text .
No hay métodos ni atributos definidos para el objeto CDATASection. Solo implementa directamente la interfaz de texto .
En este capítulo, estudiaremos sobre el objeto Comentario . Los comentarios se agregan como notas o líneas para comprender el propósito de un código XML. Los comentarios se pueden utilizar para incluir enlaces, información y términos relacionados. Estos pueden aparecer en cualquier parte del código XML.
La interfaz de comentarios hereda la interfaz CharacterData que representa el contenido del comentario.
Sintaxis
El comentario XML tiene la siguiente sintaxis:
<!-------Your comment----->
Un comentario comienza con <! - y termina con ->. Puede agregar notas textuales como comentarios entre los personajes. No debe anidar un comentario dentro del otro.
No hay métodos ni atributos definidos para el objeto Comentario. Hereda los de su padre, CharacterData , e indirectamente los de Node .
El objeto XMLHttpRequest establece un medio entre el lado del cliente y el lado del servidor de una página web que puede ser utilizado por muchos lenguajes de scripting como JavaScript, JScript, VBScript y otros navegadores web para transferir y manipular los datos XML.
Con el objeto XMLHttpRequest es posible actualizar parte de una página web sin recargar toda la página, solicitar y recibir los datos de un servidor después de que la página haya sido cargada y enviar los datos al servidor.
Sintaxis
Un objeto XMLHttpRequest se puede instalar de la siguiente manera:
xmlhttp = new XMLHttpRequest();
Para manejar todos los navegadores, incluidos IE5 e IE6, verifique si el navegador admite el objeto XMLHttpRequest como se muestra a continuación:
if(window.XMLHttpRequest) // for Firefox, IE7+, Opera, Safari, ... {
xmlHttp = new XMLHttpRequest();
} else if(window.ActiveXObject) // for Internet Explorer 5 or 6 {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
Aquí se pueden consultar ejemplos para cargar un archivo XML utilizando el objeto XMLHttpRequest
Métodos
La siguiente tabla enumera los métodos del objeto XMLHttpRequest:
S.No. | Método y descripción |
---|---|
1 | abort() Termina la solicitud actual realizada. |
2 | getAllResponseHeaders() Devuelve todos los encabezados de respuesta como una cadena, o nulo si no se ha recibido respuesta. |
3 | getResponseHeader() Devuelve la cadena que contiene el texto del encabezado especificado, o nulo si la respuesta aún no se ha recibido o el encabezado no existe en la respuesta. |
4 | open(method,url,async,uname,pswd) Se usa en conjugación con el método Send para enviar la solicitud al servidor. El método abierto especifica los siguientes parámetros:
|
5 | send(string) Se utiliza para enviar la solicitud trabajando en conjugación con el método Open. |
6 | setRequestHeader() El encabezado contiene el par etiqueta / valor al que se envía la solicitud. |
Atributos
La siguiente tabla enumera los atributos del objeto XMLHttpRequest:
S.No. | Atributo y descripción |
---|---|
1 | onreadystatechange Es una propiedad basada en eventos que se activa en cada cambio de estado. |
2 | readyState Esto describe el estado actual del objeto XMLHttpRequest. Hay cinco estados posibles de la propiedad readyState:
|
3 | responseText Esta propiedad se utiliza cuando la respuesta del servidor es un archivo de texto. |
4 | responseXML Esta propiedad se utiliza cuando la respuesta del servidor es un archivo XML. |
5 | status Da el estado del objeto de solicitud Http como un número. Por ejemplo, "404" o "200". |
6 | statusText Da el estado del objeto de solicitud Http como una cadena. Por ejemplo, "No encontrado" o "Aceptar". |
Ejemplos
El contenido de node.xml es el siguiente:
<?xml version = "1.0"?>
<Company>
<Employee category = "Technical">
<FirstName>Tanmay</FirstName>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Non-Technical">
<FirstName>Taniya</FirstName>
<LastName>Mishra</LastName>
<ContactNo>1234667898</ContactNo>
<Email>[email protected]</Email>
</Employee>
<Employee category = "Management">
<FirstName>Tanisha</FirstName>
<LastName>Sharma</LastName>
<ContactNo>1234562350</ContactNo>
<Email>[email protected]</Email>
</Employee>
</Company>
Recuperar información específica de un archivo de recursos
El siguiente ejemplo demuestra cómo recuperar información específica de un archivo de recursos utilizando el método getResponseHeader () y la propiedad readState .
<!DOCTYPE html>
<html>
<head>
<meta http-equiv = "content-type" content = "text/html; charset = iso-8859-2" />
<script>
function loadXMLDoc() {
var xmlHttp = null;
if(window.XMLHttpRequest) // for Firefox, IE7+, Opera, Safari, ... {
xmlHttp = new XMLHttpRequest();
}
else if(window.ActiveXObject) // for Internet Explorer 5 or 6 {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
return xmlHttp;
}
function makerequest(serverPage, myDiv) {
var request = loadXMLDoc();
request.open("GET", serverPage);
request.send(null);
request.onreadystatechange = function() {
if (request.readyState == 4) {
document.getElementById(myDiv).innerHTML = request.getResponseHeader("Content-length");
}
}
}
</script>
</head>
<body>
<button type = "button" onclick="makerequest('/dom/node.xml', 'ID')">Click me to get the specific ResponseHeader</button>
<div id = "ID">Specific header information is returned.</div>
</body>
</html>
Ejecución
Guarde este archivo como elementattribute_removeAttributeNS.htm en la ruta del servidor (este archivo y node_ns.xml deben estar en la misma ruta en su servidor). Obtendremos el resultado como se muestra a continuación:
Before removing the attributeNS: en
After removing the attributeNS: null
Recuperar información de encabezado de un archivo de recursos
El siguiente ejemplo demuestra cómo recuperar la información del encabezado de un archivo de recursos, utilizando el método getAllResponseHeaders() usando la propiedad readyState.
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=iso-8859-2" />
<script>
function loadXMLDoc() {
var xmlHttp = null;
if(window.XMLHttpRequest) // for Firefox, IE7+, Opera, Safari, ... {
xmlHttp = new XMLHttpRequest();
} else if(window.ActiveXObject) // for Internet Explorer 5 or 6 {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
return xmlHttp;
}
function makerequest(serverPage, myDiv) {
var request = loadXMLDoc();
request.open("GET", serverPage);
request.send(null);
request.onreadystatechange = function() {
if (request.readyState == 4) {
document.getElementById(myDiv).innerHTML = request.getAllResponseHeaders();
}
}
}
</script>
</head>
<body>
<button type = "button" onclick = "makerequest('/dom/node.xml', 'ID')">
Click me to load the AllResponseHeaders</button>
<div id = "ID"></div>
</body>
</html>
Ejecución
Guarde este archivo como http_allheader.html en la ruta del servidor (este archivo y node.xml deben estar en la misma ruta en su servidor). Obtendremos el resultado como se muestra a continuación (depende del navegador):
Date: Sat, 27 Sep 2014 07:48:07 GMT Server: Apache Last-Modified:
Wed, 03 Sep 2014 06:35:30 GMT Etag: "464bf9-2af-50223713b8a60" Accept-Ranges: bytes Vary: Accept-Encoding,User-Agent
Content-Encoding: gzip Content-Length: 256 Content-Type: text/xml
La DOMException representa un evento anormal que ocurre cuando se usa un método o una propiedad.
Propiedades
La siguiente tabla enumera las propiedades del objeto DOMException
S.No. | Descripción de propiedad |
---|---|
1 | name Devuelve una DOMString que contiene una de las cadenas asociadas con una constante de error (como se ve en la tabla a continuación). |
Tipos de error
S.No. | Tipo y descripción |
---|---|
1 | IndexSizeError El índice no está en el rango permitido. Por ejemplo, esto puede ser lanzado por el objeto Range. (Valor de código heredado: 1 y nombre de constante heredado: INDEX_SIZE_ERR) |
2 | HierarchyRequestError La jerarquía del árbol de nodos no es correcta. (Valor de código heredado: 3 y nombre de constante heredado: HIERARCHY_REQUEST_ERR) |
3 | WrongDocumentError El objeto está en el documento incorrecto. (Valor de código heredado: 4 y nombre de constante heredado: WRONG_DOCUMENT_ERR) |
4 | InvalidCharacterError La cadena contiene caracteres no válidos. (Valor de código heredado: 5 y nombre de constante heredado: INVALID_CHARACTER_ERR) |
5 | NoModificationAllowedError El objeto no se puede modificar. (Valor de código heredado: 7 y nombre de constante heredado: NO_MODIFICATION_ALLOWED_ERR) |
6 | NotFoundError El objeto no se puede encontrar aquí. (Valor de código heredado: 8 y nombre de constante heredado: NOT_FOUND_ERR) |
7 | NotSupportedError La operación no es compatible. (Valor de código heredado: 9 y nombre de constante heredado: NOT_SUPPORTED_ERR) |
8 | InvalidStateError El objeto está en un estado no válido. (Valor de código heredado: 11 y nombre de constante heredado: INVALID_STATE_ERR) |
9 | SyntaxError La cadena no coincide con el patrón esperado. (Valor de código heredado: 12 y nombre de constante heredado: SYNTAX_ERR) |
10 | InvalidModificationError El objeto no se puede modificar de esta forma. (Valor de código heredado: 13 y nombre de constante heredado: INVALID_MODIFICATION_ERR) |
11 | NamespaceError Los espacios de nombres en XML no permiten la operación. (Valor de código heredado: 14 y nombre de constante heredado: NAMESPACE_ERR) |
12 | InvalidAccessError El objeto no admite la operación o el argumento. (Valor de código heredado: 15 y nombre de constante heredado: INVALID_ACCESS_ERR) |
13 | TypeMismatchError El tipo de objeto no coincide con el tipo esperado. (Valor de código heredado: 17 y nombre de constante heredado: TYPE_MISMATCH_ERR) Este valor está en desuso, ahora se genera la excepción de JavaScript TypeError en lugar de una DOMException con este valor. |
14 | SecurityError La operación es insegura. (Valor de código heredado: 18 y nombre de constante heredado: SECURITY_ERR) |
15 | NetworkError Ocurrió un error de red. (Valor de código heredado: 19 y nombre de constante heredado: NETWORK_ERR) |
dieciséis | AbortError La operación fue abortada. (Valor de código heredado: 20 y nombre de constante heredado: ABORT_ERR) |
17 | URLMismatchError La URL proporcionada no coincide con otra URL. (Valor de código heredado: 21 y nombre de constante heredado: URL_MISMATCH_ERR) |
18 | QuotaExceededError Se ha superado la cuota. (Valor de código heredado: 22 y nombre de constante heredado: QUOTA_EXCEEDED_ERR) |
19 | TimeoutError Se agotó el tiempo de espera de la operación. (Valor de código heredado: 23 y nombre de constante heredado: TIMEOUT_ERR) |
20 | InvalidNodeTypeError El nodo es incorrecto o tiene un antepasado incorrecto para esta operación. (Valor de código heredado: 24 y nombre de constante heredado: INVALID_NODE_TYPE_ERR) |
21 | DataCloneError El objeto no se puede clonar. (Valor de código heredado: 25 y nombre de constante heredado: DATA_CLONE_ERR) |
22 | EncodingError La operación de codificación, ya sea de codificación o descodificación, falló (sin valor de código heredado y nombre de constante). |
23 | NotReadableError La operación de lectura de entrada / salida falló (sin valor de código heredado y nombre de constante). |
Ejemplo
El siguiente ejemplo demuestra cómo el uso de un documento XML con formato incorrecto provoca una DOMException.
El contenido de error.xml es el siguiente:
<?xml version = "1.0" encoding = "UTF-8" standalone = "no" ?>
<Company id = "companyid">
<Employee category = "Technical" id = "firstelement" type = "text/html">
<FirstName>Tanmay</first>
<LastName>Patil</LastName>
<ContactNo>1234567890</ContactNo>
<Email>[email protected]</Email>
</Employee>
</Company>
El siguiente ejemplo demuestra el uso del atributo de nombre :
<html>
<head>
<script>
function loadXMLDoc(filename) {
if (window.XMLHttpRequest) {
xhttp = new XMLHttpRequest();
} else // code for IE5 and IE6 {
xhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xhttp.open("GET",filename,false);
xhttp.send();
return xhttp.responseXML;
}
</script>
</head>
<body>
<script>
try {
xmlDoc = loadXMLDoc("/dom/error.xml");
var node = xmlDoc.getElementsByTagName("to").item(0);
var refnode = node.nextSibling;
var newnode = xmlDoc.createTextNode('That is why you fail.');
node.insertBefore(newnode, refnode);
} catch(err) {
document.write(err.name);
}
</script>
</body>
</html>
Ejecución
Guarde este archivo como domexcption_name.html en la ruta del servidor (este archivo y error.xml deben estar en la misma ruta en su servidor). Obtendremos el resultado como se muestra a continuación:
TypeError