最新文章专题视频专题关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
数据库有哪些 史上最简单的MySQL数据备份与还原教程 Centos7下Mysql5.7.19安装方法介绍 MySql数据库分区和分表方法的详解及分区和分表介绍 Mysql主从同步原理实现的详情介绍(图文) 惠而浦空调内机漏水 海尔空调如何拆装 奥克斯空调如何拆装 美的空调如何进行拆装 志高空调如何拆装 夏普空调内机漏水 澳柯玛空调如何拆装 空调显示e4怎么回事 TCL空调内机漏水 aux空调显示e5 三星空调内机漏水 说说IOT和mappingtable的那些事---几句话道出真相 奥克斯空调故障代码e4 科龙空调内机漏水 aux空调e4故障代码 北大计算机组成原理笔记2.1为什么要有指令系统 新手必须了解的oracle入门知识 SqlServer之旅第十一站简单说说sqlserver的执行计划 说说Oracle分区 婚姻和爱情,并不是1+1=2,而是0.5+0.5=1 擦亮自己的眼睛去看SQLServer之说说跟踪 说说Oracle监听器(altersystemregister) 新手SqlServer数据库dba需要注意的一些小细节 史上最全MySQL使用规范分享 史上最全Oracle安装配置图文教程,含TNS配置 面试题 _ 说说你是怎么数据库优化的 浏览器数据库 IndexedDB 入门教程 史上最全的 jmeter 获取 jdbc 数据使用的四种方法 史上最全的ORACLE基础教程 汽车之家社区从传统商业数据库到开源分布式数据库的架构变迁 春秋-SQLi题 MySQL查询优化一例——也说说 Using intersect 什么是数据库 史上最全的数据库面试题,不看绝对后悔(转) 史上最全的MYSQL备份方法
当前位置: 首页 - 科技 - 知识百科 - 正文

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:0731-84117792 E-MAIL:11247931@qq.com

文档

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

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

最新推荐

猜你喜欢

热门推荐

专题
Top