您的位置:首页 > Web前端 > Node.js

用ORM的思想操作XML文档,一个对象就搞定不要太简单。滚蛋吧!XmlDocument、XmlNode、Xml***……

2016-08-07 03:37 405 查看
  大家有没有这样的感受,一涉及XML文档操作就得百度一遍。是不是非!常!烦!。各种类型,各种方法,更别提为了找到一个节点多费劲。本来想写个XML操作的工具方法,写了两行一想既然XML文档是有规律的,如果抽象成一个树形结构的类,查找节点是不是就可以用lambda了,创建修改都是操作类,那不是好用得飞起!说干就干,经过两天打磨,终于是大功告成。系统默认的XML文件相关操作我就不吐槽了,来看看怎么飞起的吧。

  设计思路:

  写着好多啊,简单来说就是把XML标签分为两类:XmlChildTag子标签和XmlBaseTag基础标签。子标签内可以有子标签列表和基础标签列表,所以一个子标签就可以表示出一个XML文件的根节点。然后一个XmlFile文件类实现XmlDocument到XmlTag标签类的互相转换查找等功能。说着太空,上图:

  1.模型定义如下。注意XmlTag是抽象类。







  2.文件模型XmlFile(太长,先看下基本定义就行。项目已上github,底下有链接。)



  内部实现什么的我就不一一细讲了,有兴趣的同学去github上看SixAnts.XmlFile项目,注释应该很详细了(为了歪果仁我还写了英文注释……)。

  进入正题,怎么飞起:

  1.创建XML文件



  结果





  2.读取XML文件





  结果



  3.修改内容





  结果





  4.快速获取节点(关键飞起步骤之一)(为了展示几个不同的方法看着比较长,实际完成一次查找修改也就两三行代码搞定。)





  执行前: 执行后:





  折腾了两天,总算是差不多了。核心思想就是把标签对应成树形结构的模型类,实现模型类和XmlNode的相互转换。把类的操作映射为XmlNode的操作。

  虽然代码不多,但是为了合理好用,模型改了两三次,模型好了其实就可以自由操作了,为了快速高效,加了相关快速获取方法。我……大概是……为了世界和平吧……

  需要看源码或者想改进的同学看这里https://github.com/631320085/SixAnts.XmlFile

  想用的同学还可以直接从Nuget里搜索“SixAnts.XmlFile” 或执行命令:Install-Package SixAnts.XmlFile

  另外:Nuget里发布后DLL的注释都没了,以后有时间研究下怎么加,看完也差不多知道怎么用了吧。有不合理操作会抛出异常(异常没英文,懒得弄了)不保证没BUG啊,刚写好,持续改进中……
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: