最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

XML解析以及增删改查的操作2

来源:懂视网 责编:小采 时间:2020-11-09 08:32:32
文档

XML解析以及增删改查的操作2

XML解析以及增删改查的操作2:我写了一个节点操作的接口INodeAction,直接贴代码: getPreviousSibling方法就是获取上一个相邻的节点,getNextSibling是获取下一个相邻的节点。 getBeifen方法主要是为了文档式化用。是根节点则返回0. printSpace方法就是根据节点辈分,在写文
推荐度:
导读XML解析以及增删改查的操作2:我写了一个节点操作的接口INodeAction,直接贴代码: getPreviousSibling方法就是获取上一个相邻的节点,getNextSibling是获取下一个相邻的节点。 getBeifen方法主要是为了文档式化用。是根节点则返回0. printSpace方法就是根据节点辈分,在写文

我写了一个节点操作的接口INodeAction,直接贴代码: getPreviousSibling方法就是获取上一个相邻的节点,getNextSibling是获取下一个相邻的节点。 getBeifen方法主要是为了文档式化用。是根节点则返回0. printSpace方法就是根据节点辈分,在写文档的时候式化

我写了一个节点操作的接口INodeAction,直接贴代码:



getPreviousSibling方法就是获取上一个相邻的节点,getNextSibling是获取下一个相邻的节点。

getBeifen方法主要是为了文档格式化用。是根节点则返回0.

printSpace方法就是根据节点辈分,在写文档的时候格式化

再写了节点的基类Node:

import java.io.Serializable;
import java.util.List;
/**
 * xml文档节点基类,可以是普通节点,注释节点,文本节点
 * */
public abstract class Node implements Serializable,INodeAction{

 /**
 * 序列化版本号
 */
 private static final long serialVersionUID = 3858789701720999153L;
 /**
 * 父节点.规定 根节点的父节点为空
 * */
 protected Element father;
 /**
 * 由文档对象直接添加的节点 domFather赋值为document对象
 * */
 protected Document domFather;
 @Override
 public Integer getBeifen(){
 Integer n;
 if(father==null){
 n = 0;
 return n;
 }
 Node node = this;
 n = 0;
 while(node.father!=null){
 n++;
 node = node.father;
 if(node.father==null){
 return n;
 }
 }
 if(!(node.father==null)){
 return null;
 }
 return n;
 }
 
 public Element getFather() {
 return father;
 }
 @Override
 public String printSpace() {
 StringBuffer sb = new StringBuffer();
 Integer n = getBeifen();
 if (n == null) {
 return sb.toString();
 }
 for (int i = 0; i < n; i++) {
 sb.append(" ");
 }
 return sb.toString();
 }
 
 public Document getDomFather() {
 return domFather;
 }
 
 @Override
 public Node getPreviousSibling(){
 if(father==null){
 if(domFather==null){
 DocumentUtil.throwException("节点还没添加到文档!");
 }else{
 List nodeList = domFather.getNodeList();
 int idx = nodeList.indexOf(this);
 return idx==0?null:nodeList.get(idx-1);
 }
 }
 List nodeList = father.getNodeList();
 int idx = nodeList.indexOf(this);
 return idx==0?null:nodeList.get(idx-1);
 }
 
 @Override
 public Node getNextSibling() {
 if(father==null){
 if(domFather==null){
 DocumentUtil.throwException("节点还没添加到文档!");
 }else{
 List nodeList = domFather.getNodeList();
 int idx = nodeList.indexOf(this);
 return idx==nodeList.size()-1?null:nodeList.get(idx+1);
 }
 }
 List nodeList = father.getNodeList();
 int idx = nodeList.indexOf(this);
 return idx==nodeList.size()-1?null:nodeList.get(idx+1);
 }
}


关键在于编程的思想。有想法就什么都能实现。下面就是写节点的具体实现类了。另起一篇。

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

XML解析以及增删改查的操作2

XML解析以及增删改查的操作2:我写了一个节点操作的接口INodeAction,直接贴代码: getPreviousSibling方法就是获取上一个相邻的节点,getNextSibling是获取下一个相邻的节点。 getBeifen方法主要是为了文档式化用。是根节点则返回0. printSpace方法就是根据节点辈分,在写文
推荐度:
标签: 一个 操作 接口
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top