XML DOM ဘရာဇက်ဂျာ စကာတင်
- အရှေ့လွှတ် DOM အကွက် လှည့်ခြင်း
- နောက်လွှတ် DOM အခြေစိုက် အကွက်
不同的浏览器在 XML DOM 中处理空文本节点的方式是不同的。
DOM 解析中的浏览器差异
所有现代浏览器都支持 W3C DOM 规范。
不过,浏览器之间是有差异的。重要的区别有两点:
- 加载 XML 的方式
- 处理空白和换行的方式
在 “XML DOM ဂိုး တုံးဆေး” 这一节,已经解释了加载 XML 的不同方式。
在本节中,我们将讲解处理空白和换行的不同方式。
DOM - 空白和换行
XML 经常在节点之间含有换行或空白字符。这是在使用简单的编辑器(比如记事本)时经常出现的情况。
下面的例子(由记事本编辑)在每行之间含有 CR/LF,在每个子节点之前含有两个空格:
<book> <title>Harry Potter</title> <author>J K. Rowling</author> <year>2005</year> <price>29.99</price> </book>
ဖက်ဝါး နှင့် အချက်ပြတ် ဘရီဇာတာ အချက်ပြတ် များက ပုံမှန် အမှတ် အကျယ် သို့မဟုတ် လွှတ်တာ အကျယ် ကို စာသား အလိုက် ပြုလုပ်ကြသည်၊ သို့သော် အင်တာနက် အက်စ်တာလီ က ထိုသို့ မပြုလုပ်ပေ။
下面的代码片段显示 (books.xml 的) 根元素拥有多少个子节点:
xmlDoc=loadXMLDoc("books.xml"); x=xmlDoc.documentElement.childNodes; document.write("Number of child nodes: " + x.length);
例子解释:
- 通过使用 loadXMLDoc() 把 "books.xml" 载入 xmlDoc 中
- 获取根元素的子节点
- 输出子节点数目
结果取决于所使用的浏览器。Firefox 输出 9,而 IE 输出 4。
忽略节点间的空文本
如需忽略元素节点之间的空文本节点,需要检查节点类型。元素节点的类型是 1:
xmlDoc=loadXMLDoc("books.xml"); x=xmlDoc.documentElement.childNodes; for (i=0;i"); } }
例子解释:
- 通过使用 loadXMLDoc() 把 "books.xml" 载入 xmlDoc 中
- 获取根元素的子节点
- 检查每个子节点的节点类型。如果节点类型是 "1",则是元素节点
TIY(ကင်းလွတ်) သို့မဟုတ် TIY(ပြည့်ဆုံး)
- အရှေ့လွှတ် DOM အကွက် လှည့်ခြင်း
- နောက်လွှတ် DOM အခြေစိုက် အကွက်