XML DOM - Guida rapida

Il Document Object Model (DOM) è uno standard W3C. Definisce uno standard per l'accesso a documenti come HTML e XML.

La definizione di DOM formulata dal W3C è:

Il Document Object Model (DOM) è un'API (application programming interface) per documenti HTML e XML. Definisce la struttura logica dei documenti e il modo in cui un documento è accessibile e manipolato.

DOM definisce gli oggetti, le proprietà e i metodi (interfaccia) per accedere a tutti gli elementi XML. È suddiviso in 3 diverse parti / livelli:

  • Core DOM - modello standard per qualsiasi documento strutturato

  • XML DOM - modello standard per documenti XML

  • HTML DOM - modello standard per documenti HTML

XML DOM è un modello a oggetti standard per XML. I documenti XML hanno una gerarchia di unità informative chiamate nodi ; DOM è un'interfaccia di programmazione standard per descrivere quei nodi e le relazioni tra loro.

Poiché XML DOM fornisce anche un'API che consente a uno sviluppatore di aggiungere, modificare, spostare o rimuovere nodi in qualsiasi punto dell'albero per creare un'applicazione.

Di seguito è riportato il diagramma per la struttura DOM. Il diagramma mostra che il parser valuta un documento XML come una struttura DOM attraversando ogni nodo.

Vantaggi di XML DOM

I seguenti sono i vantaggi di XML DOM.

  • XML DOM è indipendente dalla lingua e dalla piattaforma.

  • XML DOM è traversable - Le informazioni in XML DOM sono organizzate in una gerarchia che consente allo sviluppatore di navigare nella gerarchia alla ricerca di informazioni specifiche.

  • XML DOM è modifiable - È di natura dinamica e fornisce allo sviluppatore la possibilità di aggiungere, modificare, spostare o rimuovere nodi in qualsiasi punto dell'albero.

Svantaggi di XML DOM

  • Consuma più memoria (se la struttura XML è grande) poiché il programma scritto una volta rimane in memoria tutto il tempo fino a quando ea meno che non venga rimosso esplicitamente.

  • A causa dell'ampio utilizzo della memoria, la sua velocità operativa, rispetto a SAX, è più lenta.

Ora che sappiamo cosa significa DOM, vediamo cos'è una struttura DOM. Un documento DOM è una raccolta di nodi o pezzi di informazioni, organizzati in una gerarchia. Alcuni tipi di nodi possono avere nodi figli di vario tipo e altri sono nodi foglia che non possono avere nulla sotto di essi nella struttura del documento. Di seguito è riportato un elenco dei tipi di nodo, con un elenco dei tipi di nodo che possono avere come figli:

  • Document - Elemento (massimo uno), ProcessingInstruction, Commento, DocumentType (massimo uno)

  • DocumentFragment - Element, ProcessingInstruction, Comment, Text, CDATASection, EntityReference

  • EntityReference - Element, ProcessingInstruction, Comment, Text, CDATASection, EntityReference

  • Element - Element, Text, Comment, ProcessingInstruction, CDATASection, EntityReference

  • Attr - Testo, EntityReference

  • ProcessingInstruction - Niente bambini

  • Comment - Niente bambini

  • Text - Niente bambini

  • CDATASection - Niente bambini

  • Entity - Element, ProcessingInstruction, Comment, Text, CDATASection, EntityReference

  • Notation - Niente bambini

Esempio

Considera la rappresentazione DOM del seguente 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>

Il Document Object Model del documento XML di cui sopra sarebbe il seguente:

Dal diagramma di flusso sopra, possiamo dedurre:

  • L' oggetto nodo può avere un solo oggetto nodo padre . Questo occupa la posizione sopra tutti i nodi. Ecco Company .

  • Il nodo padre può avere più nodi chiamati nodi figlio . Questi nodi figlio possono avere nodi aggiuntivi chiamati nodi dell'attributo . Nell'esempio precedente, abbiamo due nodi di attributo Tecnico e Non tecnico . Il nodo dell'attributo non è effettivamente un figlio del nodo dell'elemento, ma è ancora associato ad esso.

  • Questi nodi figlio a loro volta possono avere più nodi figlio. Il testo all'interno dei nodi è chiamato nodo di testo .

  • Gli oggetti nodo allo stesso livello vengono chiamati come fratelli.

  • Il DOM identifica:

    • gli oggetti per rappresentare l'interfaccia e manipolare il documento.

    • la relazione tra gli oggetti e le interfacce.

In questo capitolo studieremo i nodi XML DOM . Ogni XML DOM contiene le informazioni in unità gerarchiche chiamate Nodi e il DOM descrive questi nodi e la relazione tra loro.

Tipi di nodi

Il seguente diagramma di flusso mostra tutti i tipi di nodo:

I tipi più comuni di nodi in XML sono:

  • Document Node- La struttura completa del documento XML è un nodo del documento .

  • Element Node- Ogni elemento XML è un nodo elemento . Questo è anche l'unico tipo di nodo che può avere attributi.

  • Attribute Node- Ogni attributo è considerato un nodo di attributi . Contiene informazioni su un nodo elemento, ma non è effettivamente considerato come figlio dell'elemento.

  • Text Node- I testi del documento sono considerati come nodo di testo . Può essere costituito da più informazioni o solo da spazi bianchi.

Alcuni tipi meno comuni di nodi sono:

  • CData Node- Questo nodo contiene informazioni che non dovrebbero essere analizzate dal parser. Invece, dovrebbe essere trasmesso come testo normale.

  • Comment Node - Questo nodo include informazioni sui dati e di solito viene ignorato dall'applicazione.

  • Processing Instructions Node - Questo nodo contiene informazioni specificamente rivolte all'applicazione.

  • Document Fragments Node

  • Entities Node

  • Entity reference nodes

  • Notations Node

In questo capitolo studieremo l' albero dei nodi XML DOM . In un documento XML, le informazioni sono mantenute in una struttura gerarchica; questa struttura gerarchica viene chiamata Albero dei nodi . Questa gerarchia consente a uno sviluppatore di navigare nell'albero alla ricerca di informazioni specifiche, quindi ai nodi è consentito l'accesso. Il contenuto di questi nodi può quindi essere aggiornato.

La struttura dell'albero dei nodi inizia con l'elemento radice e si estende agli elementi figli fino al livello più basso.

Esempio

L'esempio seguente mostra un semplice documento XML, la cui struttura ad albero dei nodi è mostrata nel diagramma seguente:

<?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>

Come si può vedere nell'esempio sopra la cui rappresentazione pittorica (del suo DOM) è come mostrato di seguito -

  • Il nodo più in alto di un albero è chiamato root. Ilrootil nodo è <Company> che a sua volta contiene i due nodi di <Dipendente>. Questi nodi sono indicati come nodi figlio.

  • Il nodo figlio <Dipendente> del nodo radice <Company>, a sua volta è costituito dal proprio nodo figlio (<FirstName>, <LastName>, <ContactNo>).

  • I due nodi figlio, <Dipendente> hanno valori di attributo Tecnico e Non tecnico, vengono indicati come nodi di attributo .

  • Il testo all'interno di ogni nodo è chiamato nodo di testo .

XML DOM - Metodi

DOM come API contiene interfacce che rappresentano diversi tipi di informazioni che possono essere trovate in un documento XML, come elementi e testo. Queste interfacce includono i metodi e le proprietà necessari per lavorare con questi oggetti. Le proprietà definiscono le caratteristiche del nodo mentre i metodi danno il modo di manipolare i nodi.

La tabella seguente elenca le classi e le interfacce DOM:

S.No. Interfaccia e descrizione
1

DOMImplementation

Fornisce una serie di metodi per eseguire operazioni indipendenti da qualsiasi particolare istanza del modello a oggetti del documento.

2

DocumentFragment

È l'oggetto documento "leggero" o "minimo" e (come la superclasse di Document) ancora l'albero XML / HTML in un documento a tutti gli effetti.

3

Document

Rappresenta il nodo di primo livello del documento XML, che fornisce l'accesso a tutti i nodi del documento, incluso l'elemento radice.

4

Node

Rappresenta il nodo XML.

5

NodeList

Rappresenta un elenco di sola lettura di oggetti Node .

6

NamedNodeMap

Rappresenta raccolte di nodi a cui è possibile accedere in base al nome.

7

Data

Estende Node con una serie di attributi e metodi per accedere ai dati dei caratteri nel DOM.

8

Attribute

Rappresenta un attributo in un oggetto Element.

9

Element

Rappresenta il nodo dell'elemento. Deriva da Node.

10

Text

Rappresenta il nodo di testo. Deriva da CharacterData.

11

Comment

Rappresenta il nodo del commento. Deriva da CharacterData.

12

ProcessingInstruction

Rappresenta una "istruzione di elaborazione". Viene utilizzato in XML come un modo per mantenere le informazioni specifiche del processore nel testo del documento.

13

CDATA Section

Rappresenta la sezione CDATA. Deriva dal testo.

14

Entity

Rappresenta un'entità. Deriva da Node.

15

EntityReference

Questo rappresenta un riferimento all'entità nell'albero. Deriva da Node.

Discuteremo metodi e proprietà di ciascuna delle interfacce di cui sopra nei rispettivi capitoli.

In questo capitolo studieremo il caricamento e l' analisi di XML .

Per descrivere le interfacce fornite dall'API, il W3C utilizza un linguaggio astratto chiamato IDL (Interface Definition Language). Il vantaggio dell'utilizzo di IDL è che lo sviluppatore impara a utilizzare il DOM con la sua lingua preferita e può passare facilmente a una lingua diversa.

Lo svantaggio è che, poiché è astratto, IDL non può essere utilizzato direttamente dagli sviluppatori Web. A causa delle differenze tra i linguaggi di programmazione, devono avere una mappatura - o un legame - tra le interfacce astratte e i loro linguaggi concreti. DOM è stato mappato a linguaggi di programmazione come Javascript, JScript, Java, C, C ++, PLSQL, Python e Perl.

Nelle sezioni e nei capitoli seguenti, utilizzeremo Javascript come linguaggio di programmazione per caricare il file XML.

Parser

Un parser è un'applicazione software progettata per analizzare un documento, nel nostro caso un documento XML e fare qualcosa di specifico con le informazioni. Alcuni dei parser basati su DOM sono elencati nella seguente tabella:

S.No Parser e descrizione
1

JAXP

API Java di Sun Microsystem per analisi XML (JAXP)

2

XML4J

Parser XML di IBM per Java (XML4J)

3

msxml

Il parser XML di Microsoft (msxml) versione 2.0 è integrato in Internet Explorer 5.5

4

4DOM

4DOM è un parser per il linguaggio di programmazione Python

5

XML::DOM

XML :: DOM è un modulo Perl per manipolare documenti XML usando Perl

6

Xerces

Parser Java Xerces di Apache

In un'API basata su albero come DOM, il parser attraversa il file XML e crea gli oggetti DOM corrispondenti. Quindi puoi attraversare la struttura DOM avanti e indietro.

Caricamento e analisi di XML

Durante il caricamento di un documento XML, il contenuto XML può presentarsi in due forme:

  • Direttamente come file XML
  • Come stringa XML

Contenuto come file XML

L'esempio seguente mostra come caricare dati XML ( node.xml ) utilizzando Ajax e Javascript quando il contenuto XML viene ricevuto come file XML. Qui, la funzione Ajax ottiene il contenuto di un file xml e lo memorizza in XML DOM. Una volta creato l'oggetto DOM, viene quindi analizzato.

<!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 maggior parte dei dettagli del codice si trovano nel codice dello script.

  • Internet Explorer utilizza ActiveXObject ("Microsoft.XMLHTTP") per creare un'istanza dell'oggetto XMLHttpRequest, altri browser utilizzano il metodo XMLHttpRequest () .

  • il responseXML trasforma il contenuto XML direttamente in XML DOM.

  • Una volta che il contenuto XML è stato trasformato in JavaScript XML DOM, è possibile accedere a qualsiasi elemento XML utilizzando i metodi e le proprietà JS DOM. Abbiamo utilizzato le proprietà DOM come childNodes , nodeValue e metodi DOM come getElementsById (ID), getElementsByTagName (tags_name).

Esecuzione

Salva questo file come loadingexample.html e aprilo nel tuo browser. Riceverai il seguente output:

Contenuto come stringa XML

L'esempio seguente mostra come caricare dati XML utilizzando Ajax e Javascript quando il contenuto XML viene ricevuto come file XML. Qui, la funzione Ajax, ottiene il contenuto di un file xml e lo memorizza in XML DOM. Una volta creato l'oggetto DOM, viene analizzato.

<!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 maggior parte dei dettagli del codice si trovano nel codice dello script.

  • Internet Explorer utilizza ActiveXObject ("Microsoft.XMLDOM") per caricare dati XML in un oggetto DOM, altri browser utilizzano la funzione DOMParser () e il metodo parseFromString (text, 'text / xml') .

  • Il testo variabile conterrà una stringa con contenuto XML.

  • Una volta che il contenuto XML è stato trasformato in JavaScript XML DOM, è possibile accedere a qualsiasi elemento XML utilizzando i metodi e le proprietà JS DOM. Abbiamo utilizzato proprietà DOM come childNodes , nodeValue .

Esecuzione

Salva questo file come loadingexample.html e aprilo nel tuo browser. Vedrai il seguente output:

Ora che abbiamo visto come il contenuto XML si trasforma in JavaScript XML DOM, è ora possibile accedere a qualsiasi elemento XML utilizzando i metodi XML DOM.

In questo capitolo, discuteremo di XML DOM Traversing. Abbiamo studiato nel capitolo precedente come caricare un documento XML e analizzare l'oggetto DOM così ottenuto. Questo oggetto DOM analizzato può essere attraversato. Il traversing è un processo in cui il looping viene eseguito in modo sistematico attraversando ogni singolo elemento passo dopo passo in un albero dei nodi.

Esempio

Il seguente esempio (traverse_example.htm) dimostra l'attraversamento DOM. Qui attraversiamo ogni nodo figlio dell'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>
  • Questo codice carica node.xml .

  • Il contenuto XML viene trasformato in oggetto DOM JavaScript XML.

  • Si ottiene l'array di elementi (con tag Element) utilizzando il metodo getElementsByTagName ().

  • Successivamente, attraversiamo questo array e visualizziamo i valori del nodo figlio in una tabella.

Esecuzione

Salva questo file come traverse_example.html nel percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Riceverai il seguente output:

Fino ad ora abbiamo studiato la struttura DOM, come caricare e analizzare oggetti DOM XML e attraversare gli oggetti DOM. Qui vedremo come possiamo navigare tra i nodi in un oggetto DOM. Il DOM XML è costituito da varie proprietà dei nodi che ci aiutano a navigare attraverso i nodi, come:

  • parentNode
  • childNodes
  • firstChild
  • lastChild
  • nextSibling
  • previousSibling

Di seguito è riportato un diagramma di un albero dei nodi che mostra la sua relazione con gli altri nodi.

DOM - Nodo padre

Questa proprietà specifica il nodo padre come oggetto nodo.

Esempio

Il seguente esempio (navigate_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML. Quindi l'oggetto DOM viene spostato al nodo padre tramite il nodo figlio -

<!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>

Come puoi vedere nell'esempio sopra, il nodo figlio Employee passa al suo nodo padre.

Esecuzione

Salva questo file come navigate_example.html nel percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Nell'output, otteniamo il nodo padre di Employee , ovvero Company .

Primogenito

Questa proprietà è di tipo Node e rappresenta il primo nome figlio presente in NodeList.

Esempio

Il seguente esempio (first_node_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML, quindi passa al primo nodo figlio presente nell'oggetto 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 funzione get_firstChild (p) viene utilizzata per evitare i nodi vuoti. Aiuta a ottenere l'elemento firstChild dall'elenco dei nodi.

  • x = get_firstChild(xmlDoc.getElementsByTagName("Employee")[0])recupera il primo nodo figlio per il nome del tag Employee .

Esecuzione

Salvare questo file come first_node_example.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel server). Nell'output, otteniamo il primo nodo figlio di Employee, ovvero FirstName .

Ultimo bambino

Questa proprietà è di tipo Node e rappresenta l'ultimo nome figlio presente nella NodeList.

Esempio

Il seguente esempio (last_node_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML, quindi passa all'ultimo nodo figlio presente nell'oggetto 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>

Esecuzione

Salva questo file come last_node_example.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Nell'output, otteniamo l'ultimo nodo figlio di Employee, ovvero Email .

Prossimo fratello

Questa proprietà è di tipo Node e rappresenta il figlio successivo, ovvero il fratello successivo dell'elemento figlio specificato presente in NodeList.

Esempio

Il seguente esempio (nextSibling_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML che passa immediatamente al nodo successivo presente nel 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>

Esecuzione

Salvare questo file come nextSibling_example.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel server). Nell'output, otteniamo il successivo nodo di pari livello di FirstName, ovvero LastName .

Precedente Sibling

Questa proprietà è di tipo Node e rappresenta il figlio precedente, ovvero il fratello precedente dell'elemento figlio specificato presente in NodeList.

Esempio

Il seguente esempio (previoussibling_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML, quindi esplora il nodo precedente dell'ultimo nodo figlio presente nel 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>

Esecuzione

Salvare questo file come previoussibling_example.htm sul percorso del server (questo file e node.xml dovrebbero essere sullo stesso percorso nel server). Nell'output, otteniamo il nodo di pari livello precedente di Email, ovvero ContactNo .

In questo capitolo studieremo come accedere ai nodi XML DOM che sono considerati come le unità informative del documento XML. La struttura dei nodi del DOM XML consente allo sviluppatore di navigare nell'albero alla ricerca di informazioni specifiche e contemporaneamente accedere alle informazioni.

Accesso ai nodi

Di seguito sono riportati i tre modi in cui è possibile accedere ai nodi:

  • Utilizzando il getElementsByTagName () metodo

  • Facendo un ciclo o attraversando l'albero dei nodi

  • Navigando nella struttura ad albero dei nodi, utilizzando le relazioni tra i nodi

getElementsByTagName ()

Questo metodo consente di accedere alle informazioni di un nodo specificando il nome del nodo. Consente inoltre di accedere alle informazioni dell'elenco dei nodi e della lunghezza dell'elenco dei nodi.

Sintassi

Il metodo getElementByTagName () ha la seguente sintassi:

node.getElementByTagName("tagname");

Dove,

  • nodo - è il nodo del documento.

  • tagname - contiene il nome del nodo di cui desideri ottenere il valore.

Esempio

Di seguito è riportato un semplice programma che illustra l'utilizzo del metodo 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>
  • Nell'esempio precedente, stiamo accedendo alle informazioni dei nodi FirstName , LastName e Employee .

  • xmlDoc.getElementsByTagName ("FirstName") [0] .childNodes [0] .nodeValue; Questa riga accede al valore per il nodo figlio FirstName utilizzando il metodo getElementByTagName ().

  • xmlDoc.getElementsByTagName ("Employee") [0] .attributes [0] .nodeValue; Questa riga accede al valore dell'attributo del metodo Employee getElementByTagName () del nodo .

Attraversare i nodi

Questo è trattato nel capitolo Attraversamento DOM con esempi.

Navigazione tra i nodi

Questo è trattato nel capitolo Navigazione DOM con esempi.

In questo capitolo studieremo come ottenere il valore del nodo di un oggetto DOM XML. I documenti XML hanno una gerarchia di unità informative chiamate nodi. L'oggetto Node ha una proprietà nodeValue , che restituisce il valore dell'elemento.

Nelle sezioni seguenti, discuteremo:

  • Ottenere il valore del nodo di un elemento

  • Ottenere il valore dell'attributo di un nodo

Il node.xml utilizzato in tutti i seguenti esempi è il seguente:

<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>

Ottieni valore nodo

Il metodo getElementsByTagName () restituisce una NodeList di tutti gli elementi nell'ordine del documento con un dato nome di tag.

Esempio

Il seguente esempio (getnode_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML ed estrae il valore del nodo del nodo figlio Firstname (indice a 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>

Esecuzione

Salva questo file come getnode_example.htm nel percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Nell'output, otteniamo il valore del nodo come Tanmay .

Ottieni valore attributo

Gli attributi fanno parte degli elementi del nodo XML. Un elemento nodo può avere più attributi univoci. L'attributo fornisce ulteriori informazioni sugli elementi del nodo XML. Per essere più precisi, definiscono le proprietà degli elementi del nodo. Un attributo XML è sempre una coppia nome-valore. Questo valore dell'attributo è chiamato nodo dell'attributo .

Il metodo getAttribute () recupera un valore di attributo in base al nome dell'elemento.

Esempio

Il seguente esempio (get_attribute_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML ed estrae il valore dell'attributo della categoria Employee (index at 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>

Esecuzione

Salva questo file come get_attribute_example.htm nel percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Nell'output, otteniamo il valore dell'attributo come Management .

In questo capitolo, studieremo su come modificare i valori dei nodi in un oggetto DOM XML. Il valore del nodo può essere modificato come segue:

var value = node.nodeValue;

Se il nodo è un attributo, la variabile del valore sarà il valore dell'attributo; se il nodo è un nodo di testo sarà il contenuto del testo; se il nodo è un elemento sarà nullo .

Le sezioni seguenti illustreranno l'impostazione del valore del nodo per ogni tipo di nodo (attributo, nodo di testo ed elemento).

Il node.xml utilizzato in tutti i seguenti esempi è il seguente:

<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>

Modifica il valore del nodo di testo

Quando diciamo il valore di modifica dell'elemento Nodo, intendiamo modificare il contenuto di testo di un elemento (che è anche chiamato nodo di testo ). L'esempio seguente mostra come modificare il nodo di testo di un elemento.

Esempio

Il seguente esempio (set_text_node_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e modifica il valore del nodo di testo di un elemento. In questo caso, inviare un'e-mail di ciascun dipendente a [email protected] e stampare i valori.

<!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>

Esecuzione

Salvare questo file come set_text_node_example.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel server). Riceverai il seguente output:

0) [email protected]
1) [email protected]
2) [email protected]

Modifica valore del nodo attributo

L'esempio seguente mostra come modificare il nodo dell'attributo di un elemento.

Esempio

Il seguente esempio (set_attribute_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e cambia il valore del nodo dell'attributo di un elemento. In questo caso, la categoria di ciascun dipendente su admin-0, admin-1, admin-2 rispettivamente e stampa i valori.

<!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>

Esecuzione

Salva questo file come set_node_attribute_example.htm nel percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Il risultato sarebbe il seguente:

0) admin-0
1) admin-1
2) admin-2

In questo capitolo, discuteremo come creare nuovi nodi usando un paio di metodi dell'oggetto documento. Questi metodi forniscono un ambito per creare un nuovo nodo elemento, nodo testo, nodo commento, nodo sezione CDATA e nodo attributo . Se il nodo appena creato esiste già nell'oggetto elemento, viene sostituito da quello nuovo. Le sezioni seguenti lo dimostrano con esempi.

Crea un nuovo nodo Elemento

Il metodo createElement () crea un nuovo nodo elemento. Se il nodo dell'elemento appena creato esiste nell'oggetto elemento, viene sostituito da quello nuovo.

Sintassi

La sintassi per utilizzare il metodo createElement () è la seguente:

var_name = xmldoc.createElement("tagname");

Dove,

  • var_name - è il nome della variabile definita dall'utente che contiene il nome del nuovo elemento.

  • ("tagname") - è il nome del nuovo nodo elemento da creare.

Esempio

Il seguente esempio (createnewelement_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e crea un nuovo nodo elemento PhoneNo nel 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 il nuovo nodo elemento <PhoneNo>

  • x.appendChild (new_element); x contiene il nome del nodo figlio specificato <FirstName> a cui viene aggiunto il nodo del nuovo elemento.

Esecuzione

Salva questo file come createnewelement_example.htm nel percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Nell'output otteniamo il valore dell'attributo come PhoneNo .

Crea un nuovo nodo di testo

Il metodo createTextNode () crea un nuovo nodo di testo.

Sintassi

La sintassi per utilizzare createTextNode () è la seguente:

var_name = xmldoc.createTextNode("tagname");

Dove,

  • var_name - è il nome della variabile definita dall'utente che contiene il nome del nuovo nodo di testo.

  • ("tagname") - tra parentesi c'è il nome del nuovo nodo di testo da creare.

Esempio

Il seguente esempio (createtextnode_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e crea un nuovo nodo di testo Im new text node nel 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>

I dettagli del codice sopra sono i seguenti:

  • create_e = xmlDoc.createElement ("PhoneNo"); crea un nuovo elemento < PhoneNo >.

  • create_t = xmlDoc.createTextNode ("Sono un nuovo nodo di testo"); crea un nuovo nodo di testo "Im new text node" .

  • x.appendChild (create_e); il nodo di testo "Im new text node" viene aggiunto all'elemento < PhoneNo >.

  • document.write (x.getElementsByTagName ("PhoneNo") [0] .childNodes [0] .nodeValue); scrive il nuovo valore del nodo di testo nell'elemento <PhoneNo>.

Esecuzione

Salva questo file come createtextnode_example.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Nell'output, otteniamo il valore dell'attributo come ad esempio PhoneNO: Im new text node .

Crea un nuovo nodo Commento

Il metodo createComment () crea un nuovo nodo di commento. Il nodo di commento è incluso nel programma per una facile comprensione della funzionalità del codice.

Sintassi

La sintassi per utilizzare createComment () è la seguente:

var_name = xmldoc.createComment("tagname");

Dove,

  • var_name - è il nome della variabile definita dall'utente che contiene il nome del nuovo nodo di commento.

  • ("tagname") - è il nome del nuovo nodo di commento da creare.

Esempio

Il seguente esempio (createcommentnode_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e crea un nuovo nodo di commento, "Company is the parent node" nel 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>

Nell'esempio sopra -

  • create_comment = xmlDoc.createComment ("La società è il nodo padre") creates a specified comment line.

  • x.appendChild (create_comment) In questa riga, "x" contiene il nome dell'elemento <Company> a cui è aggiunta la riga di commento.

Esecuzione

Salva questo file come createcommentnode_example.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Nell'output, otteniamo il valore dell'attributo poiché Company è il nodo padre .

Crea nuovo nodo sezione CDATA

Il metodo createCDATASection () crea un nuovo nodo di sezione CDATA. Se il nodo della sezione CDATA appena creato esiste nell'oggetto elemento, viene sostituito da quello nuovo.

Sintassi

La sintassi per utilizzare createCDATASection () è la seguente:

var_name = xmldoc.createCDATASection("tagname");

Dove,

  • var_name - è il nome della variabile definita dall'utente che contiene il nome del nuovo nodo della sezione CDATA.

  • ("tagname") - è il nome del nuovo nodo della sezione CDATA da creare.

Esempio

Il seguente esempio (createcdatanode_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e crea un nuovo nodo di sezione CDATA, "Crea esempio CDATA" nel 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>

Nell'esempio sopra -

  • create_CDATA = xmlDoc.createCDATASection ("Crea esempio CDATA") crea un nuovo nodo di sezione CDATA, "Crea esempio CDATA"

  • x.appendChild (create_CDATA) qui, x contiene l'elemento specificato <Employee> indicizzato a 0 a cui viene aggiunto il valore del nodo CDATA.

Esecuzione

Salva questo file come createcdatanode_example.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Nell'output, otteniamo il valore dell'attributo come Crea esempio CDATA .

Crea un nuovo nodo Attribute

Per creare un nuovo nodo attributo, viene utilizzato il metodo setAttributeNode () . Se il nodo dell'attributo appena creato esiste nell'oggetto elemento, viene sostituito da quello nuovo.

Sintassi

La sintassi per utilizzare il metodo createElement () è la seguente:

var_name = xmldoc.createAttribute("tagname");

Dove,

  • nome_var - è il nome della variabile definita dall'utente che contiene il nome del nuovo nodo dell'attributo.

  • ("tagname") - è il nome del nuovo nodo attributo da creare.

Esempio

Il seguente esempio (createattributenode_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e crea una nuova sezione del nodo dell'attributo nel 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>

Nell'esempio sopra -

  • create_a = xmlDoc.createAttribute ("Category") crea un attributo con il nome <section>.

  • create_a.nodeValue = "Management" crea il valore "A" per l'attributo <section>.

  • x [0] .setAttributeNode (create_a) questo valore dell'attributo è impostato sull'elemento del nodo <Employee> indicizzato a 0.

In questo capitolo, discuteremo i nodi dell'elemento esistente. Fornisce un mezzo per:

  • aggiungere nuovi nodi figlio prima o dopo i nodi figlio esistenti

  • inserire i dati all'interno del nodo di testo

  • aggiungi nodo attributo

I seguenti metodi possono essere utilizzati per aggiungere / accodare i nodi a un elemento in un DOM:

  • appendChild()
  • insertBefore()
  • insertData()

appendChild ()

Il metodo appendChild () aggiunge il nuovo nodo figlio dopo il nodo figlio esistente.

Sintassi

La sintassi del metodo appendChild () è la seguente:

Node appendChild(Node newChild) throws DOMException

Dove,

  • newChild - È il nodo da aggiungere

  • Questo metodo restituisce il nodo aggiunto.

Esempio

Il seguente esempio (appendchildnode_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e aggiunge il nuovo PhoneNo figlio all'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>

Nell'esempio sopra -

  • utilizzando il metodo createElement (), viene creato un nuovo elemento PhoneNo .

  • Il nuovo elemento PhoneNo viene aggiunto all'elemento FirstName utilizzando il metodo appendChild ().

Esecuzione

Salva questo file come appendchildnode_example.htm nel percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Nell'output, otteniamo il valore dell'attributo come PhoneNo .

insertBefore ()

Il metodo insertBefore () , inserisce i nuovi nodi figlio prima dei nodi figlio specificati.

Sintassi

La sintassi del metodo insertBefore () è la seguente:

Node insertBefore(Node newChild, Node refChild) throws DOMException

Dove,

  • newChild - È il nodo da inserire

  • refChild - È il nodo di riferimento, ovvero il nodo prima del quale deve essere inserito il nuovo nodo.

  • Questo metodo restituisce il nodo che viene inserito.

Esempio

L'esempio seguente (insertnodebefore_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e inserisce una nuova Email figlio prima dell'elemento specificato <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>

Nell'esempio sopra -

  • utilizzando il metodo createElement (), viene creato un nuovo elemento Email .

  • Il nuovo elemento Email viene aggiunto prima dell'elemento Email utilizzando il metodo insertBefore ().

  • y.length fornisce il numero totale di elementi aggiunti prima e dopo il nuovo elemento.

Esecuzione

Salva questo file come insertnodebefore_example.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Riceveremo il seguente output:

No of Email elements before inserting was: 3
No of Email elements after inserting is: 4

insertData ()

Il metodo insertData (), inserisce una stringa all'offset di unità di 16 bit specificato.

Sintassi

InsertData () ha la seguente sintassi:

void insertData(int offset, java.lang.String arg) throws DOMException

Dove,

  • offset - è l'offset del carattere in cui inserire.

  • arg - è la parola chiave per inserire i dati. Racchiude i due parametri offset e stringa tra parentesi separati da virgola.

Esempio

Il seguente esempio (addtext_example.htm) analizza un documento XML (" node.xml ") in un oggetto DOM XML e inserisce nuovi dati MiddleName nella posizione specificata nell'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");- Qui, x contiene il nome del nome figlio specificato, ad esempio <FirstName>. Inseriamo quindi in questo nodo di testo il dato "MiddleName" a partire dalla posizione 6.

Esecuzione

Salva questo file come addtext_example.htm nel percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Riceveremo quanto segue nell'output:

Tanmay
TanmayMiddleName

In questo capitolo, studieremo l'operazione di sostituzione del nodo in un oggetto DOM XML. Come sappiamo, tutto nel DOM è mantenuto in un'unità informativa gerarchica nota come nodo e il nodo di sostituzione fornisce un altro modo per aggiornare questi nodi specificati o un nodo di testo.

Di seguito sono riportati i due metodi per sostituire i nodi.

  • replaceChild()
  • replaceData()

replaceChild ()

Il metodo replaceChild () sostituisce il nodo specificato con il nuovo nodo.

Sintassi

InsertData () ha la seguente sintassi:

Node replaceChild(Node newChild, Node oldChild) throws DOMException

Dove,

  • newChild - è il nuovo nodo da inserire nell'elenco dei figli.

  • oldChild - è il nodo che viene sostituito nell'elenco.

  • Questo metodo restituisce il nodo sostituito.

Esempio

Il seguente esempio (replacenode_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e sostituisce il nodo specificato <FirstName> con il nuovo 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>

Esecuzione

Salva questo file come replacenode_example.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Otterremo l'output come mostrato di seguito -

Content of FirstName element before replace operation
Tanmay
Taniya
Tanisha

Content of FirstName element after replace operation
Taniya
Tanisha

replaceData ()

Il metodo replaceData () sostituisce i caratteri che iniziano all'offset di unità di 16 bit specificato con la stringa specificata.

Sintassi

ReplaceData () ha la seguente sintassi:

void replaceData(int offset, int count, java.lang.String arg) throws DOMException

Dove

  • offset : è l'offset da cui iniziare la sostituzione.

  • count - è il numero di unità a 16 bit da sostituire. Se la somma di offset e conteggio supera la lunghezza, vengono sostituite tutte le unità a 16 bit fino alla fine dei dati.

  • arg - la DOMString con cui l'intervallo deve essere sostituito.

Esempio

Il seguente esempio ( replace_example.htm ) analizza un documento XML ( node.xml ) in un oggetto DOM XML e lo sostituisce.

<!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>

Nell'esempio sopra -

  • x.replaceData (2,3, "999"); - Qui x contiene il testo dell'elemento specificato <ContactNo> il cui testo è sostituito dal nuovo testo "9999999" , a partire dalla posizione 1 fino alla lunghezza di 5 .

Esecuzione

Salvare questo file come sostituito_esempio.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel server). Otterremo l'output come mostrato di seguito -

ContactNo before replace operation: 1234567890

ContactNo after replace operation: 199999997890

In questo capitolo, studieremo l' operazione di rimozione del nodo DOM XML . L'operazione di rimozione del nodo rimuove il nodo specificato dal documento. Questa operazione può essere implementata per rimuovere i nodi come il nodo di testo, il nodo dell'elemento o un nodo dell'attributo.

Di seguito sono riportati i metodi utilizzati per l'operazione di rimozione del nodo:

  • removeChild()

  • removeAttribute()

removeChild ()

Il metodo removeChild () rimuove il nodo figlio indicato da oldChild dall'elenco dei figli e lo restituisce. La rimozione di un nodo figlio equivale a rimuovere un nodo di testo. Quindi, la rimozione di un nodo figlio rimuove il nodo di testo ad esso associato.

Sintassi

La sintassi per utilizzare removeChild () è la seguente:

Node removeChild(Node oldChild) throws DOMException

Dove,

  • oldChild - è il nodo che viene rimosso.

  • Questo metodo restituisce il nodo rimosso.

Esempio: rimuovere il nodo corrente

Il seguente esempio (removecurrentnode_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e rimuove il nodo specificato <ContactNo> dal nodo padre.

<!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>

Nell'esempio sopra -

  • x = xmlDoc.getElementsByTagName ("ContactNo") [0] ottiene l'elemento <ContactNo> indicizzato a 0.

  • x.parentNode.removeChild (x); rimuove l'elemento <ContactNo> indicizzato a 0 dal nodo padre.

Esecuzione

Salva questo file come removecurrentnode_example.htm nel percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Otteniamo il seguente risultato:

Before remove operation, total ContactNo elements: 3
After remove operation, total ContactNo elements: 2

Esempio: rimuovere il nodo di testo

Il seguente esempio (removetextNode_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e rimuove il nodo figlio specificato <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>

Nell'esempio sopra -

  • x = xmlDoc.getElementsByTagName ("FirstName") [0]; - ottiene il primo elemento <FirstName> nella x indicizzata a 0.

  • y = x.childNodes [0]; - in questa riga y contiene il nodo figlio da rimuovere.

  • x.removeChild (y); - rimuove il nodo figlio specificato.

Esecuzione

Salva questo file come removetextNode_example.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Otteniamo il seguente risultato:

Text node of child node before removal is: 1
Text node of child node after removal is: 0

removeAttribute ()

Il metodo removeAttribute () rimuove un attributo di un elemento in base al nome.

Sintassi

La sintassi per utilizzare removeAttribute () è la seguente:

void removeAttribute(java.lang.String name) throws DOMException

Dove,

  • nome : è il nome dell'attributo da rimuovere.

Esempio

Il seguente esempio (removeelementattribute_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e rimuove il nodo dell'attributo specificato.

<!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>

Nell'esempio sopra -

  • document.write (x [1] .getAttribute ('category')); - viene richiamato il valore della categoria di attributi indicizzata in prima posizione.

  • x [1] .removeAttribute ('category'); - rimuove il valore dell'attributo.

Esecuzione

Salva questo file come removeelementattribute_example.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Otteniamo il seguente risultato:

Non-Technical
null

In questo capitolo, discuteremo l' operazione Clone Node su un oggetto DOM XML. L'operazione di clonazione del nodo viene utilizzata per creare una copia duplicata del nodo specificato. cloneNode () viene utilizzato per questa operazione.

cloneNode ()

Questo metodo restituisce un duplicato di questo nodo, ovvero funge da costruttore di copia generico per i nodi. Il nodo duplicato non ha un genitore (parentNode è null) e nessun dato utente.

Sintassi

Il metodo cloneNode () ha la seguente sintassi:

Node cloneNode(boolean deep)
  • deep - Se true, clona ricorsivamente la sottostruttura sotto il nodo specificato; se falso, clona solo il nodo stesso (e i suoi attributi, se è un elemento).

  • Questo metodo restituisce il nodo duplicato.

Esempio

L'esempio seguente (clonenode_example.htm) analizza un documento XML ( node.xml ) in un oggetto DOM XML e crea una copia completa del primo 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>

Come puoi vedere nell'esempio sopra, abbiamo impostato il parametro cloneNode () su true . Quindi ogni elemento figlio sotto l' elemento Employee viene copiato o clonato.

Esecuzione

Salva questo file come clonenode_example.htm sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Otterremo l'output come mostrato di seguito -

Tanmay Patil, 1234567890, [email protected]
Taniya Mishra, 1234667898, [email protected]
Tanisha Sharma, 1234562350, [email protected]
Tanmay Patil, 1234567890, [email protected]

Noterai che il primo elemento Employee viene clonato completamente.

L' interfaccia del nodo è il tipo di dati principale per l'intero Document Object Model. Il nodo viene utilizzato per rappresentare un singolo elemento XML nell'intero albero del documento.

Un nodo può essere qualsiasi tipo che sia un nodo attributo, un nodo di testo o qualsiasi altro nodo. Gli attributi nodeName, nodeValue e gli attributi sono inclusi come meccanismo per ottenere le informazioni sul nodo senza passare alla specifica interfaccia derivata.

Attributi

La tabella seguente elenca gli attributi dell'oggetto Node :

Attributo genere Descrizione
attributi NamedNodeMap È di tipo NamedNodeMap contenente gli attributi di questo nodo (se è un elemento) o null in caso contrario. Questo è stato rimosso. Fare riferimento alle specifiche
baseURI DOMString Viene utilizzato per specificare l'URI di base assoluto del nodo.
childNodes NodeList È un NodeList che contiene tutti i figli di questo nodo. Se non ci sono figli, questo è un NodeList che non contiene nodi.
Primogenito Nodo Specifica il primo figlio di un nodo.
ultimo bambino Nodo Specifica l'ultimo figlio di un nodo.
localName DOMString Viene utilizzato per specificare il nome della parte locale di un nodo. Questo è stato rimosso. Fare riferimento alle specifiche .
namespaceURI DOMString Specifica l'URI dello spazio dei nomi di un nodo. Questo è stato rimosso. Fare riferimento alle specifiche
nextSibling Nodo Restituisce il nodo immediatamente successivo a questo nodo. Se non esiste tale nodo, restituisce null.
nodeName DOMString Il nome di questo nodo, a seconda del tipo.
nodeType corto non firmato È un codice che rappresenta il tipo di oggetto sottostante.
nodeValue DOMString Viene utilizzato per specificare il valore di un nodo a seconda dei tipi.
ownerDocument Documento Specifica l' oggetto Document associato al nodo.
parentNode Nodo Questa proprietà specifica il nodo padre di un nodo.
prefisso DOMString Questa proprietà restituisce il prefisso dello spazio dei nomi di un nodo. Questo è stato rimosso. Fare riferimento alle specifiche
previousSibling Nodo Specifica il nodo immediatamente precedente al nodo corrente.
textContent DOMString Specifica il contenuto testuale di un nodo.

Tipi di nodi

Abbiamo elencato i tipi di nodo come di seguito:

  • 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

Metodi

La tabella sottostante elenca i diversi metodi dell'oggetto nodo:

S.No. Metodo e descrizione
1 appendChild (Node newChild)

Questo metodo aggiunge un nodo dopo l'ultimo nodo figlio del nodo dell'elemento specificato. Restituisce il nodo aggiunto.

2 cloneNode (booleano profondo)

Questo metodo viene utilizzato per creare un nodo duplicato, se sottoposto a override in una classe derivata. Restituisce il nodo duplicato.

3 compareDocumentPosition (Node altro)

Questo metodo viene utilizzato per confrontare la posizione del nodo corrente con un nodo specificato in base all'ordine del documento. Restituisce un segno breve , come il nodo è posizionato relativamente al nodo di riferimento.

4

getFeature(DOMString feature, DOMString version)

Restituisce l'oggetto DOM che implementa le API specializzate della funzionalità e della versione specificate, se presenti, o null se non sono presenti oggetti. Questo è stato rimosso. Fare riferimento alle specifiche .

5

getUserData(DOMString key)

Recupera l'oggetto associato a una chiave su questo nodo. L'oggetto deve prima essere stato impostato su questo nodo chiamando setUserData con la stessa chiave. Restituisce il DOMUserData associato alla chiave specificata su questo nodo o null se non ce n'era. Questo è stato rimosso. Fare riferimento alle specifiche .

6

hasAttributes()

Restituisce se questo nodo (se è un elemento) ha attributi o meno. Restituisce true se un attributo è presente nel nodo specificato, altrimenti restituisce false . Questo è stato rimosso. Fare riferimento alle specifiche .

7 hasChildNodes ()

Restituisce se questo nodo ha figli. Questo metodo restituisce true se il nodo corrente ha nodi figlio, altrimenti false .

8 insertBefore (Node newChild, Node refChild)

Questo metodo viene utilizzato per inserire un nuovo nodo come figlio di questo nodo, direttamente prima di un figlio esistente di questo nodo. Restituisce il nodo che si sta inserendo.

9 isDefaultNamespace (DOMString namespaceURI)

Questo metodo accetta un URI dello spazio dei nomi come argomento e restituisce un valore booleano con un valore true se lo spazio dei nomi è lo spazio dei nomi predefinito sul nodo specificato o false in caso contrario.

10 isEqualNode (argomento nodo)

Questo metodo verifica se due nodi sono uguali. Restituisce vero se i nodi sono uguali, falso in caso contrario.

11

isSameNode(Node other)

Questo metodo restituisce se il nodo corrente è lo stesso nodo di quello specificato. Restituisce vero se i nodi sono gli stessi, falso in caso contrario. Questo è stato rimosso. Fare riferimento alle specifiche .

12

isSupported(DOMString feature, DOMString version)

Questo metodo restituisce se il modulo DOM specificato è supportato dal nodo corrente. Restituisce true se la funzionalità specificata è supportata su questo nodo, false in caso contrario. Questo è stato rimosso. Fare riferimento alle specifiche .

13 lookupNamespaceURI (prefisso DOMString)

Questo metodo ottiene l'URI dello spazio dei nomi associato al prefisso dello spazio dei nomi.

14 lookupPrefix (DOMString namespaceURI)

Questo metodo restituisce il prefisso più vicino definito nello spazio dei nomi corrente per l'URI dello spazio dei nomi. Restituisce un prefisso dello spazio dei nomi associato se trovato o null se non viene trovato.

15 normalizzare()

La normalizzazione aggiunge tutti i nodi di testo inclusi i nodi di attributo che definiscono una forma normale in cui la struttura dei nodi che contengono elementi, commenti, istruzioni di elaborazione, sezioni CDATA e riferimenti di entità separa i nodi di testo, cioè né nodi di testo adiacenti né nodi di testo vuoti.

16 removeChild (Node oldChild)

Questo metodo viene utilizzato per rimuovere un nodo figlio specificato dal nodo corrente. Ciò restituisce il nodo rimosso.

17 replaceChild (Node newChild, Node oldChild)

Questo metodo viene utilizzato per sostituire il vecchio nodo figlio con un nuovo nodo. Ciò restituisce il nodo sostituito.

18

setUserData(DOMString key, DOMUserData data, UserDataHandler handler)

Questo metodo associa un oggetto a una chiave su questo nodo. L'oggetto può essere successivamente recuperato da questo nodo chiamando getUserData con la stessa chiave. Questo restituisce il DOMUserData precedentemente associato alla chiave data su questo nodo. Questo è stato rimosso. Fare riferimento alle specifiche .

L'oggetto NodeList specifica l'astrazione di una raccolta ordinata di nodi. Gli elementi nella NodeList sono accessibili tramite un indice integrale, a partire da 0.

Attributi

La tabella seguente elenca gli attributi dell'oggetto NodeList:

Attributo genere Descrizione
lunghezza non firmato a lungo Fornisce il numero di nodi nell'elenco dei nodi.

Metodi

Il seguente è l'unico metodo dell'oggetto NodeList.

S.No. Metodo e descrizione
1 articolo()

Restituisce l' elemento index -esimo nella raccolta. Se index è maggiore o uguale al numero di nodi nell'elenco, restituisce null.

L' oggetto NamedNodeMap viene utilizzato per rappresentare raccolte di nodi a cui è possibile accedere in base al nome.

Attributi

La tabella seguente elenca la proprietà dell'oggetto NamedNodeMap.

Attributo genere Descrizione
lunghezza non firmato a lungo Fornisce il numero di nodi in questa mappa. L'intervallo di indici di nodi figlio validi è compreso tra 0 e length-1 incluso.

Metodi

La tabella seguente elenca i metodi dell'oggetto NamedNodeMap .

S.No. Metodi e descrizione
1 getNamedItem ()

Recupera il nodo specificato in base al nome.

2 getNamedItemNS ()

Recupera un nodo specificato dal nome locale e dall'URI dello spazio dei nomi.

3 articolo ()

Restituisce l' elemento index -esimo nella mappa. Se index è maggiore o uguale al numero di nodi in questa mappa, restituisce null.

4 removeNamedItem ()

Rimuove un nodo specificato dal nome.

5 removeNamedItemNS ()

Rimuove un nodo specificato dal nome locale e dall'URI dello spazio dei nomi.

6 setNamedItem ()

Aggiunge un nodo utilizzando il relativo attributo nodeName . Se un nodo con quel nome è già presente in questa mappa, viene sostituito da quello nuovo.

7 setNamedItemNS ()

Aggiunge un nodo utilizzando i suoi namespaceURI e localName . Se un nodo con quell'URI dello spazio dei nomi e quel nome locale è già presente in questa mappa, viene sostituito da quello nuovo. La sostituzione di un nodo da sola non ha alcun effetto.

L' oggetto DOMImplementation fornisce una serie di metodi per l'esecuzione di operazioni indipendenti da qualsiasi particolare istanza del modello di oggetti del documento.

Metodi

La tabella seguente elenca i metodi dell'oggetto DOMImplementation -

S.No. Metodo e descrizione
1 createDocument (namespaceURI, qualificatoName, doctype)

Crea un oggetto documento DOM del tipo specificato con il suo elemento documento.

2 createDocumentType (qualificatoName, publicId, systemId)

Crea un nodo DocumentType vuoto .

3

getFeature(feature, version)

Questo metodo restituisce un oggetto specializzato che implementa le API specializzate della funzionalità e della versione specificate. Questo è stato rimosso. Fare riferimento alle specifiche .

4 hasFeature (funzionalità, versione)

Questo metodo verifica se l'implementazione DOM implementa una funzione e una versione specifiche.

Gli oggetti DocumentType sono la chiave per accedere ai dati del documento e nel documento l'attributo doctype può avere il valore null o il valore dell'oggetto DocumentType. Questi oggetti DocumentType fungono da interfaccia per le entità descritte per un documento XML.

Attributi

La tabella seguente elenca gli attributi dell'oggetto DocumentType :

Attributo genere Descrizione
nome DOMString Restituisce il nome del DTD che è scritto immediatamente accanto alla parola chiave! DOCTYPE.
entità NamedNodeMap Restituisce un oggetto NamedNodeMap contenente le entità generali, sia esterne che interne, dichiarate nel DTD.
notazioni NamedNodeMap Restituisce una NamedNodeMap contenente le notazioni dichiarate nella DTD.
internalSubset DOMString Restituisce un sottoinsieme interno come stringa o null se non ce n'è. Questo è stato rimosso. Fare riferimento alle specifiche .
ID pubblico DOMString Restituisce l'identificatore pubblico del sottoinsieme esterno.
systemId DOMString Restituisce l'identificatore di sistema del sottoinsieme esterno. Questo può essere un URI assoluto o meno.

Metodi

DocumentType eredita i metodi dal suo genitore, Node , e implementa l' interfaccia ChildNode .

ProcessingInstruction fornisce le informazioni specifiche dell'applicazione che sono generalmente incluse nella sezione prologo del documento XML.

Le istruzioni di elaborazione (PI) possono essere utilizzate per passare le informazioni alle applicazioni. I PI possono apparire ovunque nel documento al di fuori del markup. Possono apparire nel prologo, inclusa la definizione del tipo di documento (DTD), nel contenuto testuale o dopo il documento.

Un PI inizia con un tag speciale <? e termina con ?>. L'elaborazione del contenuto termina immediatamente dopo la stringa?> è incontrato.

Attributi

La tabella seguente elenca gli attributi dell'oggetto ProcessingInstruction :

Attributo genere Descrizione
dati DOMString È un carattere che descrive le informazioni che l'applicazione deve elaborare immediatamente prima del?>.
bersaglio DOMString Ciò identifica l'applicazione a cui sono diretti l'istruzione oi dati.

L'interfaccia dell'entità rappresenta un'entità nota, analizzata o non analizzata, in un documento XML. L' attributo nodeName ereditato da Node contiene il nome dell'entità.

Un oggetto Entity non ha alcun nodo padre e tutti i suoi nodi successori sono di sola lettura.

Attributi

La tabella seguente elenca gli attributi dell'oggetto Entity :

Attributo genere Descrizione
inputEncoding DOMString Specifica la codifica utilizzata dall'entità analizzata esterna. Il suo valore è nullo se è un'entità dal sottoinsieme interno o se non è noto.
notationName DOMString Per un'entità non analizzata, fornisce il nome della notazione e il suo valore è nullo per le entità analizzate.
ID pubblico DOMString Fornisce il nome dell'identificatore pubblico associato all'entità.
systemId DOMString Fornisce il nome dell'identificatore di sistema associato all'entità.
xmlEncoding DOMString Fornisce la codifica xml inclusa come parte della dichiarazione di testo per l'entità analizzata esterna, altrimenti null.
xmlVersion DOMString Fornisce la versione xml inclusa come parte della dichiarazione di testo per l'entità analizzata esterna, altrimenti null.

Gli oggetti EntityReference sono i riferimenti di entità generali che vengono inseriti nel documento XML fornendo l'ambito per sostituire il testo. L'oggetto EntityReference non funziona per le entità predefinite poiché sono considerate espanse dal processore HTML o XML.

Questa interfaccia non ha proprietà o metodi propri ma eredita da Node .

In questo capitolo studieremo l' oggetto XML DOM Notation . La proprietà dell'oggetto notazione fornisce un ambito per riconoscere il formato degli elementi con un attributo di notazione, una particolare istruzione di elaborazione o dati non XML. Le proprietà ei metodi dell'oggetto Node possono essere eseguiti sull'oggetto Notation poiché anche questo è considerato come un oggetto Node.

Questo oggetto eredita metodi e proprietà da Node . Il suo nodeName è il nome della notazione. Non ha genitore.

Attributi

La tabella seguente elenca gli attributi dell'oggetto Notation :

Attributo genere Descrizione
ID pubblico DOMString Fornisce il nome dell'identificatore pubblico associato alla notazione.
systemID DOMString Fornisce il nome dell'identificatore di sistema associato alla notazione.

Gli elementi XML possono essere definiti come blocchi costitutivi di XML. Gli elementi possono comportarsi come contenitori per contenere testo, elementi, attributi, oggetti multimediali o tutti questi. Ogni volta che il parser analizza un documento XML rispetto al formato corretto, il parser naviga attraverso un nodo dell'elemento. Un nodo elemento contiene il testo al suo interno che viene chiamato come nodo di testo.

L'oggetto elemento eredita le proprietà ei metodi dell'oggetto Node poiché anche l'oggetto elemento è considerato come un nodo. Oltre alle proprietà e ai metodi dell'oggetto nodo, ha le seguenti proprietà e metodi.

Proprietà

La tabella seguente elenca gli attributi dell'oggetto Element :

Attributo genere Descrizione
tagName DOMString Fornisce il nome del tag per l'elemento specificato.
schemaTypeInfo TypeInfo Rappresenta le informazioni sul tipo associate a questo elemento. Questo è stato rimosso. Fare riferimento alle specifiche .

Metodi

La tabella seguente elenca i metodi dell'oggetto Element:

Metodi genere Descrizione
getAttribute () DOMString Recupera il valore dell'attributo, se esistente, per l'elemento specificato.
getAttributeNS () DOMString Recupera un valore di attributo in base al nome locale e all'URI dello spazio dei nomi.
getAttributeNode () Attr Recupera il nome del nodo dell'attributo dall'elemento corrente.
getAttributeNodeNS () Attr Recupera un nodo Attr in base al nome locale e all'URI dello spazio dei nomi.
getElementsByTagName () NodeList Restituisce un NodeList di tutti gli elementi discendenti con un dato nome di tag, nell'ordine del documento.
getElementsByTagNameNS () NodeList Restituisce un NodeList di tutti gli elementi discendenti con un determinato nome locale e URI dello spazio dei nomi nell'ordine del documento.
hasAttribute () booleano Restituisce vero quando un attributo con un dato nome è specificato su questo elemento o ha un valore predefinito, altrimenti falso.
hasAttributeNS () booleano Restituisce true quando un attributo con un determinato nome locale e URI dello spazio dei nomi viene specificato su questo elemento o ha un valore predefinito, altrimenti false.
removeAttribute () Nessun valore di ritorno Rimuove un attributo in base al nome.
removeAttributeNS Nessun valore di ritorno Rimuove un attributo in base al nome locale e all'URI dello spazio dei nomi.
removeAttributeNode () Attr Il nodo dell'attributo specificato viene rimosso dall'elemento.
setAttribute () Nessun valore di ritorno Imposta un nuovo valore di attributo sull'elemento esistente.
setAttributeNS () Nessun valore di ritorno Aggiunge un nuovo attributo. Se un attributo con lo stesso nome locale e URI dello spazio dei nomi è già presente sull'elemento, il suo prefisso viene modificato per essere la parte del prefisso di qualificatoName e il suo valore viene modificato per essere il parametro value.
setAttributeNode () Attr Imposta un nuovo nodo di attributo sull'elemento esistente.
setAttributeNodeNS Attr Aggiunge un nuovo attributo. Se un attributo con quel nome locale e quell'URI dello spazio dei nomi è già presente nell'elemento, viene sostituito da quello nuovo.
setIdAttribute Nessun valore di ritorno Se il parametro isId è true, questo metodo dichiara l'attributo specificato come un attributo ID determinato dall'utente. Questo è stato rimosso. Fare riferimento alle specifiche .
setIdAttributeNS Nessun valore di ritorno Se il parametro isId è true, questo metodo dichiara l'attributo specificato come un attributo ID determinato dall'utente. Questo è stato rimosso. Fare riferimento alle specifiche .

L' interfaccia Attr rappresenta un attributo in un oggetto Element. In genere, i valori consentiti per l'attributo sono definiti in uno schema associato al documento. Gli oggetti Attr non sono considerati come parte dell'albero del documento poiché non sono effettivamente nodi figlio dell'elemento che descrivono. Pertanto, per i nodi figlio parentNode , previousSibling e nextSibling il valore dell'attributo è null .

Attributi

La tabella seguente elenca gli attributi dell'oggetto Attribute :

Attributo genere Descrizione
nome DOMString Questo dà il nome dell'attributo.
specificato booleano È un valore booleano che restituisce true se il valore dell'attributo esiste nel documento.
valore DOMString Restituisce il valore dell'attributo.
ownerElement Elemento Fornisce il nodo a cui è associato l'attributo o null se l'attributo non è in uso.
isId booleano Restituisce se l'attributo è noto per essere di tipo ID (cioè per contenere un identificatore per il suo elemento proprietario) o meno.

In questo capitolo, studieremo l'oggetto XML DOM CDATASection . Il testo presente in un documento XML viene analizzato o non analizzato a seconda di ciò che viene dichiarato. Se il testo viene dichiarato come Parse Character Data (PCDATA), viene analizzato dal parser per convertire un documento XML in un oggetto DOM XML. D'altra parte, se il testo viene dichiarato come CDATA (unparsed Character Data), il testo all'interno non viene analizzato dal parser XML. Questi non sono considerati come markup e non espandono le entità.

Lo scopo dell'utilizzo dell'oggetto CDATASection è quello di sfuggire ai blocchi di testo contenenti caratteri che sarebbero altrimenti considerati markup. "]]>", questo è l'unico delimitatore riconosciuto in una sezione CDATA che termina la sezione CDATA.

L'attributo CharacterData.data contiene il testo contenuto nella sezione CDATA. Questa interfaccia eredita l' interfaccia CharatcterData tramite l' interfaccia Text .

Non esistono metodi e attributi definiti per l'oggetto CDATASection. Implementa direttamente solo l' interfaccia di testo .

In questo capitolo studieremo l' oggetto Comment . I commenti vengono aggiunti come note o righe per comprendere lo scopo di un codice XML. I commenti possono essere utilizzati per includere collegamenti, informazioni e termini correlati. Questi possono apparire ovunque nel codice XML.

L'interfaccia del commento eredita l' interfaccia CharacterData che rappresenta il contenuto del commento.

Sintassi

Il commento XML ha la seguente sintassi:

<!-------Your comment----->

Un commento inizia con <! - e termina con ->. Puoi aggiungere note testuali come commenti tra i personaggi. Non devi annidare un commento dentro l'altro.

Non esistono metodi e attributi definiti per l'oggetto Comment. Eredita quelli del suo genitore, CharacterData , e indirettamente quelli di Node .

L'oggetto XMLHttpRequest stabilisce un mezzo tra il lato client e il lato server di una pagina Web che può essere utilizzato da molti linguaggi di scripting come JavaScript, JScript, VBScript e altri browser Web per trasferire e manipolare i dati XML.

Con l'oggetto XMLHttpRequest è possibile aggiornare la parte di una pagina web senza ricaricare l'intera pagina, richiedere e ricevere i dati da un server dopo che la pagina è stata caricata e inviare i dati al server.

Sintassi

Un oggetto XMLHttpRequest può essere istanziato come segue:

xmlhttp = new XMLHttpRequest();

Per gestire tutti i browser, inclusi IE5 e IE6, controlla se il browser supporta l'oggetto XMLHttpRequest come di seguito:

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");
}

Esempi per caricare un file XML utilizzando l'oggetto XMLHttpRequest possono essere riferiti qui

Metodi

La tabella seguente elenca i metodi dell'oggetto XMLHttpRequest -

S.No. Metodo e descrizione
1

abort()

Termina la richiesta corrente effettuata.

2

getAllResponseHeaders()

Restituisce tutte le intestazioni della risposta come stringa o null se non è stata ricevuta alcuna risposta.

3

getResponseHeader()

Restituisce la stringa contenente il testo dell'intestazione specificata o null se la risposta non è stata ancora ricevuta o l'intestazione non esiste nella risposta.

4

open(method,url,async,uname,pswd)

Viene utilizzato in combinazione con il metodo Send per inviare la richiesta al server. Il metodo open specifica i seguenti parametri:

  • method - specifica il tipo di richiesta, ad esempio Get o Post.

  • url - è la posizione del file.

  • async- indica come deve essere gestita la richiesta. È un valore booleano. dove,

    • "true" significa che la richiesta viene elaborata in modo asincrono senza attendere una risposta Http.

    • "false" significa che la richiesta viene elaborata in modo sincrono dopo aver ricevuto la risposta Http.

  • uname - è il nome utente.

  • pswd - è la password.

5

send(string)

Serve per inviare la richiesta lavorando in coniugazione con il metodo Open.

6

setRequestHeader()

L'intestazione contiene la coppia etichetta / valore a cui viene inviata la richiesta.

Attributi

La tabella seguente elenca gli attributi dell'oggetto XMLHttpRequest -

S.No. Attributo e descrizione
1

onreadystatechange

È una proprietà basata su eventi che viene attivata ad ogni cambio di stato.

2

readyState

Descrive lo stato attuale dell'oggetto XMLHttpRequest. Sono disponibili cinque stati possibili della proprietà readyState:

  • readyState = 0 - significa che la richiesta deve ancora essere inizializzata.

  • readyState = 1 - la richiesta è impostata.

  • readyState = 2 - la richiesta viene inviata.

  • readyState = 3 - la richiesta è in elaborazione.

  • readyState = 4 - la richiesta è completata.

3

responseText

Questa proprietà viene utilizzata quando la risposta dal server è un file di testo.

4

responseXML

Questa proprietà viene utilizzata quando la risposta dal server è un file XML.

5

status

Fornisce lo stato dell'oggetto richiesta HTTP come numero. Ad esempio, "404" o "200".
6

statusText

Fornisce lo stato dell'oggetto richiesta HTTP come stringa. Ad esempio, "Non trovato" o "OK".

Esempi

I contenuti di node.xml sono i seguenti:

<?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>

Recupera informazioni specifiche di un file di risorse

L'esempio seguente mostra come recuperare informazioni specifiche di un file di risorse utilizzando il metodo getResponseHeader () e la proprietà 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>

Esecuzione

Salva questo file come elementattribute_removeAttributeNS.htm nel percorso del server (questo file e node_ns.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Otterremo l'output come mostrato di seguito -

Before removing the attributeNS: en
After removing the attributeNS: null

Recupera le informazioni di intestazione di un file di risorse

L'esempio seguente mostra come recuperare le informazioni di intestazione di un file di risorse, utilizzando il metodo getAllResponseHeaders() utilizzando la proprietà 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>

Esecuzione

Salvare questo file come http_allheader.html sul percorso del server (questo file e node.xml dovrebbero trovarsi sullo stesso percorso nel server). Otterremo l'output come mostrato di seguito (dipende dal browser) -

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

Il DOMException rappresenta un evento anomalo accade quando si utilizza un metodo o una proprietà.

Proprietà

La tabella sottostante elenca le proprietà dell'oggetto DOMException

S.No. Proprietà e descrizione
1

name

Restituisce una stringa DOMString che contiene una delle stringhe associate a una costante di errore (come mostrato nella tabella seguente).

Tipi di errore

S.No. Tipo e descrizione
1

IndexSizeError

L'indice non è nell'intervallo consentito. Ad esempio, questo può essere lanciato dall'oggetto Range. (Valore del codice precedente: 1 e nome della costante precedente: INDEX_SIZE_ERR)

2

HierarchyRequestError

La gerarchia dell'albero dei nodi non è corretta. (Valore del codice precedente: 3 e nome della costante precedente: HIERARCHY_REQUEST_ERR)

3

WrongDocumentError

L'oggetto è nel documento sbagliato. (Valore del codice precedente: 4 e nome della costante precedente: WRONG_DOCUMENT_ERR)

4

InvalidCharacterError

La stringa contiene caratteri non validi. (Valore del codice precedente: 5 e nome della costante precedente: INVALID_CHARACTER_ERR)

5

NoModificationAllowedError

L'oggetto non può essere modificato. (Valore del codice precedente: 7 e nome della costante precedente: NO_MODIFICATION_ALLOWED_ERR)

6

NotFoundError

L'oggetto non può essere trovato qui. (Valore del codice precedente: 8 e nome della costante precedente: NOT_FOUND_ERR)

7

NotSupportedError

L'operazione non è supportata. (Valore del codice precedente: 9 e nome della costante precedente: NOT_SUPPORTED_ERR)

8

InvalidStateError

L'oggetto è in uno stato non valido. (Valore del codice precedente: 11 e nome della costante precedente: INVALID_STATE_ERR)

9

SyntaxError

La stringa non corrisponde al modello previsto. (Valore del codice precedente: 12 e nome della costante precedente: SYNTAX_ERR)

10

InvalidModificationError

L'oggetto non può essere modificato in questo modo. (Valore del codice precedente: 13 e nome della costante precedente: INVALID_MODIFICATION_ERR)

11

NamespaceError

L'operazione non è consentita da Namespaces in XML. (Valore del codice precedente: 14 e nome della costante precedente: NAMESPACE_ERR)

12

InvalidAccessError

L'oggetto non supporta l'operazione o l'argomento. (Valore del codice precedente: 15 e nome della costante precedente: INVALID_ACCESS_ERR)

13

TypeMismatchError

Il tipo di oggetto non corrisponde al tipo previsto. (Valore del codice legacy: 17 e nome della costante legacy: TYPE_MISMATCH_ERR) Questo valore è deprecato, l'eccezione TypeError JavaScript viene ora sollevata invece di un'eccezione DOMException con questo valore.

14

SecurityError

L'operazione è insicura. (Valore del codice precedente: 18 e nome della costante precedente: SECURITY_ERR)

15

NetworkError

Si è verificato un errore di rete. (Valore del codice precedente: 19 e nome della costante precedente: NETWORK_ERR)

16

AbortError

L'operazione è stata interrotta. (Valore del codice precedente: 20 e nome della costante precedente: ABORT_ERR)

17

URLMismatchError

L'URL fornito non corrisponde a un altro URL. (Valore del codice precedente: 21 e nome della costante precedente: URL_MISMATCH_ERR)

18

QuotaExceededError

La quota è stata superata. (Valore del codice precedente: 22 e nome della costante precedente: QUOTA_EXCEEDED_ERR)

19

TimeoutError

L'operazione è scaduta. (Valore del codice precedente: 23 e nome della costante precedente: TIMEOUT_ERR)

20

InvalidNodeTypeError

Il nodo non è corretto o ha un antenato errato per questa operazione. (Valore del codice precedente: 24 e nome della costante precedente: INVALID_NODE_TYPE_ERR)

21

DataCloneError

L'oggetto non può essere clonato. (Valore codice precedente: 25 e nome costante precedente: DATA_CLONE_ERR)

22

EncodingError

L'operazione di codifica, essendo una codifica o una decodifica, non è riuscita (nessun valore del codice legacy e nome della costante).

23

NotReadableError

L'operazione di lettura di input / output non è riuscita (nessun valore del codice legacy e nome della costante).

Esempio

L'esempio seguente mostra come l'utilizzo di un documento XML non ben formato provoca una DOMException.

I contenuti di error.xml sono i seguenti:

<?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>

L'esempio seguente dimostra l'utilizzo dell'attributo name :

<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>

Esecuzione

Salva questo file come domexcption_name.html sul percorso del server (questo file e error.xml dovrebbero trovarsi sullo stesso percorso nel tuo server). Otterremo l'output come mostrato di seguito -

TypeError