添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
Document doc=........;
Element root=doc.getDocumentElement();
Element nameNode=(Element)root.getElementsByTagName_r(name).item(0);
String name=nameNode.getNodeValue();

通过这种方式得到的 name 值为 null
网络上也给出了解决方案

String name=nameNode.getFirstChild().getNodeValue();

这样我们就可以得到 admin 了。问题解决!可是为什么呢?

凡事多问个为什么

我们需要解决两个问题:这个 null 是哪里来的?怎么获得 admin 这个文本呢?

  • 这个 null 是哪里来的?

网友也给出了答案:在Node接口的官方文档中有详细解释(参考API文档)。
这里写图片描述

可以看出: Element 的nodeValue是null(问题的根源被找到了), Text 的nodeValue是该文本节点的内容。

  • 怎么获得 admin 这个文本呢?

在说明这个问题之前,我们首先要了解两个接口 Element Text

这里我们知道 Text 是用来表示 Element Attr 的文本内容(在XML中是字符数据)。
在demo.xml中 name 节点是 ELement 的一个实例(我们暂且可以这么理解),而我们想要得到的 admin Text 的一个实例。这一点我们也可以通过获取NodeType来证实。

int nameType=nameNode.getNodeType();//1 ELEMENT_NODE
int textType=nameNode.getFirstChild().getNodeType();//3 TEXT_NODE

这就是说admin( Text )节点是name( ELement )的子节点,这也是为什么我们可以通过nameNode.getFirstChild().getNodeValue()来获取admin这个文本节点(值)。

回归本源,凡事是为了什么

然而事情并没有结束,回到我们最初的问题。
说了这么多我们的目的也就是为了获取admin。

String name=nameNode.getTextContent();

到这里圆满结束。

站在巨人的肩膀

参考资料:
http://blog.sina.com.cn/s/blog_5da93c8f0100t28h.html

Ajax应用中很常见的行为便是后台把数据用XML包裹好返回给浏览器,浏览器解析XML,得到 node Value 如果单个 node 中内容很长(超过4096字节),这时在FireFox/Mozilla中就要注意了,内容将会被FrieFox分解为多个text Node ,每个大小为4096字节。这种情况可以用下列函数处理(IE兼容) 代码如下:function get Node Value ( node )  {          if( node && node .hasChild Node s()){                  //return node .firstChild. node Value ;
最近在写解析XML的程序,可能是更新jar包的原因,原有程序居然报错了,程序代码: org.w3c. dom . Node List rsdes = resDoc.get Element sByTagName("resultdescription"); if(rsdes!= null &&rsdes.getLength()>0){ throw new RuntimeException(rsdes.item(
在学习 DOM 解析XML的内容时,最先学习了读取XML中的内容,但是利用get Node Value ()方法时,常常获得 null ;要不然就是报 Null PointerException空指针错误。于是我就查阅了相关的内容,将这个知识点总结一下。首先贴出我的XML中的内容: <?xml version="1.0" encoding="UTF-8"?> <Languages cat="it"...
缺少前提判定:利用条件语句加以判定,不为空的时候再用相应的实体类去接收对象,并给相应控件赋值: Intent intent=getIntent(); if(intent.getSerializableExtra("item")!= null ){ JsbMiddle middle= (JsbMiddle) intent.getSerializableExtr
get Node Value 是获取当前节点的值; element 在setTextContent的时候其实是给节点  #text  设置值;所以 element 获取 value 时调用getFirstChild的 value 实际 调用的是第一个#text  ,而 element 直接调用get Node Value 为空值
文章目录一、树的概念1、特点2、树的术语3、树的种类4、树的存储与表示5、常见的树的应用场景二、二叉树1、概念2、性质 一、树的概念 树是一种抽象数据类型(ADT)或是视作这种抽象数据类型的数据结构 每个节点有零个或多个子节点 没有父节点的节点称为根节点 每一个非根节点有且只有一个父节点 除了根节点外,每个子节点可以分为**多个不相交(因为都只有一个父节点)**的子树 2、树的术语 节点的度:一个节点含有的子树的个数称为该节点的度 树的度:一棵树中,最大的节点的度称为树的度 叶节点或终端节点
Java中可以使用XPath来获取XML文档中节点的值。 首先,需要创建一个`javax.xml.xpath.XPath`对象,然后使用`XPathExpression`来编译XPath表达式,最后使用`XPathExpression.evaluate`方法来执行XPath表达式并获取节点的值。 例如,下面的代码演示了如何使用XPath获取XML文档中的节点值: ```java import javax.xml.xpath.XPath; import javax.xml.xpath.XPathConstants; import javax.xml.xpath.XPathExpression; import javax.xml.xpath.XPathFactory; import org.w3c. dom .Document; import org.w3c. dom . Node List; // ... XPathFactory xpathFactory = XPathFactory.newInstance(); XPath xpath = xpathFactory.newXPath(); // 编译XPath表达式 XPathExpression expr = xpath.compile("/root/ node /text()"); // 执行XPath表达式并获取节点列表 Node List node s = ( Node List) expr.evaluate(doc, XPathConstants. NODE SET); // 遍历节点列表并输出节点的值 for (int i = 0; i < node s.getLength(); i++) { System.out.println( node s.item(i).get Node Value ()); 其中,`doc`是一个`org.w3c. dom .Document`对象,表示XML文档。 注意,需要导入以下依赖才能使用上述代码: import javax.xml.xpath.XPath; import javax.xml.xpath.XPathConstants; import javax.xml.xpath.XPathExpression; import javax.xml.xpath.XPathFactory;