--- title: DOMParser slug: Web/API/DOMParser translation_of: Web/API/DOMParser ---
{{APIRef("DOM")}}{{SeeCompatTable}}
DOMParser
puede analizar gramaticalmente (parsear, en adelante) código XML o HTML almacenado en una cadena de texto y convertirlo en un Documento DOM. DOMParser
está especificado en DOM Parsing and Serialization.
Tener en cuenta que XMLHttpRequest soporta parsear XML y HTML desde recursos direccionables por URL.
Para crear un objeto DOMParser
simplemente usar new DOMParser()
.
Para más información sobre crear un objeto DOMParser
en extensiones Firefox, por favor vea la documentación de nsIDOMParser
.
Una vez creado el objeto parseador, puedes parsear XML desde una cadena de texto usando el método parseFromString:
var parser = new DOMParser(); var doc = parser.parseFromString(stringContainingXMLSource, "application/xml");
Es importante tener en cuenta que si el proceso de parseado falla, actualmente DOMParser
no arroja una excepción, pero devuelve en cambio un documento de error (see {{Bug(45566)}}):
<parsererror xmlns="http://www.mozilla.org/newlayout/xml/parsererror.xml"> (error description) <sourcetext>(a snippet of the source XML)</sourcetext> </parsererror>
Los errores de parseo son reportados también a la Consola de errores, con el URI del documento (ver debajo) como el origen del error.
El DOMParser
puede ser usado para parsear un documento SVG {{geckoRelease("10.0")}} o un documento HTML{{geckoRelease("12.0")}}. Hay 3 resultados diferentes posibles, dependiendo del tipo MIME dado. Si el tipo del MIME es text/xml
, el objeto resultante será un XMLDocument
, si el tipo MIME es image/svg+xml
será un SVGDocument,
y si el tipo MIME es text/html
será un HTMLDocument
.
var parser = new DOMParser(); var doc = parser.parseFromString(stringContainingXMLSource, "application/xml"); // returns a Document, but not a SVGDocument nor a HTMLDocument parser = new DOMParser(); doc = parser.parseFromString(stringContainingXMLSource, "image/svg+xml"); // returns a SVGDocument, which also is a Document. parser = new DOMParser(); doc = parser.parseFromString(stringContainingHTMLSource, "text/html"); // returns a HTMLDocument, which also is a Document.
/* * DOMParser HTML extension * 2012-09-04 * * By Eli Grey, http://eligrey.com * Public domain. * NO WARRANTY EXPRESSED OR IMPLIED. USE AT YOUR OWN RISK. */ /*! @source https://gist.github.com/1129031 */ /*global document, DOMParser*/ (function(DOMParser) { "use strict"; var proto = DOMParser.prototype , nativeParse = proto.parseFromString ; // Firefox/Opera/IE throw errors on unsupported types try { // WebKit returns null on unsupported types if ((new DOMParser()).parseFromString("", "text/html")) { // text/html parsing is natively supported return; } } catch (ex) {} proto.parseFromString = function(markup, type) { if (/^\s*text\/html\s*(?:;|$)/i.test(type)) { var doc = document.implementation.createHTMLDocument("") ; if (markup.toLowerCase().indexOf('<!doctype') > -1) { doc.documentElement.innerHTML = markup; } else { doc.body.innerHTML = markup; } return doc; } else { return nativeParse.apply(this, arguments); } }; }(DOMParser));
Ver artículo aquí: nsIDOMParser
Especificación | Estado | Comentario |
---|---|---|
{{SpecName('DOM Parsing', '#the-domparser-interface', 'DOMParser')}} | {{Spec2('DOM Parsing')}} | Definición inicial |
Característica | Chrome | Edge | Firefox (Gecko) | Internet Explorer | Opera | Safari (WebKit) |
---|---|---|---|---|---|---|
XML support | {{CompatChrome(1)}} | {{CompatVersionUnknown}} | {{CompatGeckoDesktop(1)}} | {{CompatIE(9)}} | {{CompatOpera(8)}} | {{CompatSafari(3.2)}} |
SVG support | {{CompatChrome(4)}} | {{CompatVersionUnknown}} | {{CompatGeckoDesktop(10.0)}} | {{CompatIE(10)}} | {{CompatOpera(15)}} | {{CompatSafari(3.2)}} |
HTML support | {{CompatChrome(30)}} | {{CompatVersionUnknown}} | {{CompatGeckoDesktop(12.0)}} | {{CompatIE(10)}} | {{CompatOpera(17)}} | {{CompatSafari(7.1)}} |
Característica | Android | Edge | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
XML support | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | {{CompatVersionUnknown}} | {{CompatUnknown}} | {{CompatVersionUnknown}} | {{CompatUnknown}} |
SVG support | {{CompatUnknown}} | {{CompatVersionUnknown}} | {{CompatGeckoMobile(10.0)}} | {{CompatUnknown}} | {{CompatUnknown}} | {{CompatUnknown}} |
HTML support | {{CompatUnknown}} | {{CompatVersionUnknown}} | {{CompatGeckoMobile(12.0)}} | {{CompatUnknown}} | {{CompatUnknown}} | {{CompatUnknown}} |