å ´åã«ãã£ã¦ã¯ãXML ã®ã³ã³ãã³ããè§£æã㦠DOM ããªã¼ã«å¤æããå¿ è¦ãããã§ããããã¾ãã¯éã«ãæ¢åã® DOM ããªã¼ã XML ã«ã·ãªã¢ã©ã¤ãºãããã¨ãããã¾ãããã®è¨äºã§ã¯ãXML ã®ã·ãªã¢ã©ã¤ãºã¨è§£æã®ä¸è¬çãªä½æ¥ã容æã«ãããããã¦ã§ããã©ãããã©ã¼ã ã§æä¾ããããªãã¸ã§ã¯ãã«æ³¨ç®ãã¾ãã
XMLSerializer
DOM ããªã¼ãã·ãªã¢ã©ã¤ãºããXML ãå«ãæååã«å¤æãã¾ãã
DOMParser
XML ãå«ãæååãè§£æã㦠DOM ããªã¼ãæ§ç¯ããå
¥åãã¼ã¿ã«åºã¥ãã¦é©å㪠XMLDocument
ã¾ã㯠Document
ãè¿ãã¾ãã
fetch()
URL ããã³ã³ãã³ããèªã¿è¾¼ã¿ã¾ãã XML ã³ã³ãã³ãã¯ã DOMParser
ã使ç¨ãã¦æ§æè§£æã§ããããã¹ãæååã¨ãã¦è¿ããã¾ãã
XMLHttpRequest
fetch()
ã®å身ã§ãã fetch()
API ã¨ã¯ç°ãªãã XMLHttpRequest
ã¯ããã®ãããã㣠responseXML
ã使ç¨ãã¦ããªã½ã¼ã¹ã Document
ã¨ãã¦è¿ããã¨ãã§ãã¾ãã
XML ææ¸ã®ç¹å®ã®é¨åã®ã¢ãã¬ã¹ãå«ãæååã使ãããããã®ã¢ãã¬ã¹ã«åºã¥ã㦠XML ãã¼ããç¹å®ããæè¡ã
次ã®ããããã®æ¹æ³ã§ XML ææ¸ã使ãã¾ãï¼ãã㯠Document
ã®ã¤ã³ã¹ã¿ã³ã¹ã§ãï¼ã
ãã®ä¾ã§ã¯ãDOMParser
ã使ç¨ãã¦æååã® XML ã®æçã DOM ããªã¼ã«å¤æãã¾ãã
const xmlStr = '<q id="a"><span id="b">hey!</span></q>';
const parser = new DOMParser();
const doc = parser.parseFromString(xmlStr, "application/xml");
// ã«ã¼ãè¦ç´ ã®ååã¾ãã¯ã¨ã©ã¼ã¡ãã»ã¼ã¸ãåºåãã¾ã
const errorNode = doc.querySelector("parsererror");
if (errorNode) {
console.log("æ§æè§£æä¸ã«ã¨ã©ã¼çºç");
} else {
console.log(doc.documentElement.nodeName);
}
URL ã§ã¢ãã¬ã¹æå®ãå¯è½ãªãªã½ã¼ã¹ã DOM ããªã¼ã«æ§æè§£æãã fetch ã®ä½¿ç¨
URL ã¢ãã¬ã¹æå®ãå¯è½ãª XML ãã¡ã¤ã«ãèªã¿è¾¼ã¿è§£æã㦠DOM ããªã¼ã«ãããµã³ãã«ã³ã¼ããæ¬¡ã«ç¤ºãã¾ãã
fetch("example.xml")
.then((response) => response.text())
.then((text) => {
const parser = new DOMParser();
const doc = parser.parseFromString(text, "text/xml");
console.log(doc.documentElement.nodeName);
});
ãã®ã³ã¼ãã¯ãªã½ã¼ã¹ãããã¹ãæååã¨ãã¦åå¾ãã DOMParser.parseFromString()
ã使ç¨ã㦠XMLDocument
ãæ§ç¯ãã¾ãã
ææ¸ã HTML ã§ããå ´åãä¸è¨ã®ã³ã¼ã㯠Document
ãè¿ãã¾ããææ¸ã XML ã§ããå ´åãè¿ããããªãã¸ã§ã¯ã㯠XMLDocument
ã«ãªãã¾ãããã® 2 種é¡ã¯åºæ¬çã«åãã§ããããã®éãã¯ä¸»ã«æ´å²çãªé¨åã§ãããå·®å¥åã«ã¯ããã¤ãã®å®ç¨çãªå©ç¹ãããã¾ãã
ã¡ã¢: HTMLDocument
ã¤ã³ã¿ã¼ãã§ã¤ã¹ãããã¾ãããç¬ç«ããåã§ããã¨ã¯éãã¾ãããç¬ç«ããåã¨ãã¦æ±ããã©ã¦ã¶ã¼ãããã¾ãããåãªã Document
ã¤ã³ã¿ã¼ãã§ã¤ã¹ã¸ã®ã¨ã¤ãªã¢ã¹ã¨ãã¦ãããã©ã¦ã¶ã¼ãããã¾ãã
Document
ãããæãXMLSerializer.serializeToString()
ã¡ã½ãããç¨ãã¦æç« ã® DOM ããªã¼ã XML ã«ã·ãªã¢ã©ã¤ãºãç´ããã¨ãã§ãã¾ãã
åã®ç¯ã§ä½æãã XML ææ¸ãã·ãªã¢ã©ã¤ãºããã«ã¯ã以ä¸ã®æ¹æ³ãç¨ãã¦ãã ããã
DOM ããªã¼ãæååã«ã·ãªã¢ã©ã¤ãºã¾ããDOM ããªã¼ã®ä½ææ¹æ³ã§èª¬æãããæ¹æ³ã§ DOM ããªã¼ã使ãã¾ãããããã¯ã fetch()
ã§åå¾ãã DOM ããªã¼ãç¨ãã¾ãã
DOM ããªã¼ doc
ã XML æååã«ã·ãªã¢ã©ã¤ãºããã«ã¯ã以ä¸ã®ããã« XMLSerializer.serializeToString()
ãå¼ã³åºãã¾ãã
const serializer = new XMLSerializer();
const xmlStr = serializer.serializeToString(doc);
HTML ææ¸ã®ã·ãªã¢ã©ã¤ãº
DOM ã HTML ææ¸ã§ããå ´åãserializeToString()
ãç¨ãã¦ã·ãªã¢ã©ã¤ãºãããã¨ãã§ãã¾ãããããåç´ãªæ¹æ³ãããã¾ããElement.innerHTML
ãããã㣠(æå®ãããã¼ãã®åå«ã®ã¿ãå¾ããå ´å) ã¾ã㯠Element.outerHTML
ãããã㣠(æå®ãããã¼ãã¨ãã®åå«ãå¾ããå ´å) ãç¨ããã°ããã§ãã
const docInnerHtml = document.documentElement.innerHTML;
ãããå®è¡ããã¨ã docHTML
ã¯ææ¸ã®å
容ãããªãã¡ <body>
è¦ç´ ã®å
容ã表ã HTML ãå
¥ã£ãæååã«ãªãã¾ãã
ãã®ã³ã¼ããç¨ããã¨ã <body>
ã¨ãã®åå«ã«å¯¾å¿ãã HTML ãå¾ããã¨ãã§ãã¾ãã
const docOuterHtml = document.documentElement.outerHTML;
é¢é£é
ç®
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4