CYQ.Data 数据层框架

CYQ.Data 是一款由路过秋天创作的支持多数据库应用[Txt,Xml,Access,MSSQL,Oracle,SQLite,MySql]的底层数据库操作类库,使用本类库可以轻松快速开发项目(QQ群:6033006)。

CYQ.Data.Xml XmlHelper 帮助类的使用帮助

快速使用帮助 | | | 发表日期 :2011/4/25 1:00:32#楼主  

PS:V5版本已变更名称为XHtmlAction类名。


一:XmlHelper  类的说明

使用此类,可以轻松操作Xml/Html。

二:XmlHelper 使用说明:

1:实例化:

XmlHelper doc=new XmlHelper(...);

方法原型:

public XmlHelper()//默认构造函数[操作无名称空间的Xml]

public XmlHelper(bool forHtml)//参数为true时表示操作Html,为false时表示操作xml

public XmlHelper(string nameSpaceUrl)//操作名称空间的Xml

2:Xml/Html加载:

方法原型:

public void LoadXml(string xml)//从字符串加载

public bool Load(string absFilePath)//从文件路径加载

public bool Load(string absFilePath, XmlCacheLevel level)//带设置xml/html缓存级别

示例代码:

XmlHelper doc = new XmlHelper (true);//操作html
if (doc.Load(Server.MapPath("html/index.html"), XmlCacheLevel.Hour))
{
  //加载html成功,并缓存html 1小时
}

2:单结点查询:

方法原型:

public XmlNode GetByID(string id)//根据ID查找结点
public XmlNode GetByID(string id, XmlNode parentNode)//在parentNode节点下根据ID找结点
public XmlNode GetByName(string name)//根据Name查找结点
public XmlNode GetByName(string name, XmlNode parentNode))

public XmlNode Get(string tag, string attr, string value, XmlNode parentNode)//根据标签,属性及属性值和是否带父节点查找一个结点。

示例:

xml示例节点:

<p id="pID">这里有pID</p><div id="divID" ><p id="pID">pID又来一个</p></div>

XmlNode node = doc.GetByID("pID", doc.GetByID("divID"));//获取里面的ID节点

3:列表结点查询:

方法原型:

public XmlNodeList GetList(string tag)
public XmlNodeList GetList(string tag, XmlNode parentNode)
public XmlNodeList GetList(string tag, string attr)
public XmlNodeList GetList(string tag, string attr, XmlNode parentNode)
public XmlNodeList GetList(string tag, string attr, string value)
public XmlNodeList GetList(string tag, string attr, string value, XmlNode parentNode)

示例:

xml示例节点:

<p id="pID">这里有pID</p><div id="divID" ><p id="pID">pID又来一个</p></div>

XmlNodeList nodeList = doc.GetList("p","id","pid");//获取所有p的节点

4:创建结点:

方法原型:

public XmlNode CreateNode(string tag, string text, params string[] attrAndValue)

public void CreateNodeTo(XmlNode parentNode, string tag, string text, params string[] attrAndValue)

示例:

xml示例节点:

一开始节点:<div id="divID"></div>

代码创建:doc.CreateNodeTo(doc.GetByID("divID"), "p", "pID又来一个", "id", "pID");

创建后变成:<div id="divID" ><p id="pID">pID又来一个</p></div>

5:添加结点:

方法原型:

public void AppendNode(XmlNode parentNode, XmlNode childNode)

public void AppendNode(XmlNode parentNode, XmlNode childNode, int position)//position为将childNode放在parentNode的第N个子节点之后

6:删除结点:

方法原型:

public void Clear(XmlNode node)//保留节点,只清除内容和属性
public void Remove(XmlNode node)//删除节点
public void Remove(string id)//根据节点ID删除节点
public void RemoveChild(string id, int index)//移除某ID节点下的第N个子节点
public void RemoveChild(XmlNode node, int index)//移除某节点下的第N个子节点
public void RemoveAttrList(params string[] attrNames)//移除整个文档的指定属性

7:结点交互|替换|插入[前后]

方法原型:

public void InterChange(XmlNode xNodeFirst, XmlNode xNodeLast)//两节点互换位置

public void ReplaceNode(XmlNode newNode, XmlNode oldNode)//节点替换

public void InsertAfter(XmlNode newNode, XmlNode refNode)//将newNode插入到refNode之后

public void InsertBefore(XmlNode newNode, XmlNode refNode)//将newNode插入到refNode之前

8:节点判断:

方法原型:

public bool Contains(string id)//是否存在某ID节点

public bool Contains(string id, XmlNode parentNode)//在parentNode下是否存在某ID节点

9:属性操作

方法原型:

public bool HasAttr(string nodeID, string attrName)//某节点是否存在某属性

public bool HasAttr(XmlNode node, string attrName)

public string GetAttrValue(string nodeID, string attrName, params string[] defaultValue)//获取某节点的属性值,并允许设置默认值

public string GetAttrValue(XmlNode node, string attrName, params string[] defaultValue)

public void RemoveAttr(string nodeID, params string[] attrNames)//移除节点指定属性

public void RemoveAttr(XmlNode node, params string[] attrNames)

10:保存为xml/html功能

方法原型:

public void Save()//保存并替换原始加载文件

public void Save(string fileName)//保存到指定的文件路径

三:与CYQ.Data.Table的交互功能

1:原生的赋值操作

方法原型:

public void Set(string id, string value)//为ID节点的InnerXml属性赋值
public void Set(string id, SetType setType, params string[] values)//为ID节点的setType[不同属性]赋值,如果是A链接,可赋多个值。
public void Set(XmlNode node, SetType setType, params string[] values)

示例:

原始:<a id="aID">这是一个原始A链接</id>

doc.Set("aID", SetType.A,"这是A链接","http://cyqdata.com","_blank");

结果:<a id="aID" href=http://cyqdata.com target="_blank">这是A链接</id>

2:与MDataRow的交互[ID=任意三个字母前缀+字段名称]

方法原型:

public void LoadData(MDataRow row)//加载行数据
public void SetFor(string id)//将row的数据赋给ID节点的InnerXml属性
public void SetFor(string id, SetType setType)//将row的数据赋给ID节点的指定属性
public void SetFor(string id, SetType setType, params string[] values)//最后参数允许格式化值

示例:

原始<span id="labHits">点击</span>

doc.SetFor("labHits", SetType.InnerText, ValueReplace.Source + "(" + ValueReplace.New + ")");

结果:<span id="labhits">点击(12)</span>

ValueReplace.Source:指原来节点属性的值

ValueReplace.New: 指数据库的值

3:与MDataTable的交互

方法原型:

public void LoadData(MDataTable table)//加载表格

//SetForeach将ID节点复制并循环
public void SetForeach(string id, SetType setType, params object[] formatValues)
public void SetForeach(string id, string text, params object[] formatValues)
public delegate string SetForeachEventHandler(string text, object[] values, int row);
public event SetForeachEventHandler OnForeach;//针对每行进行格式化

示例一:SetForeach(string id, string text, params object[] formatValues)

原始标签:<select id="selClassID"></select>
doc.LoadData(table);//加载表格
doc.SetForeach("selClassID", "<option value="{0}" >{1}</option>", Class.ID, IsUserLang ? Class.Name : Class.PKey);
结果标签:<select id="selClassID"><option value="1">标识1</option>....</select>

这语句将循环出一个下拉列表。

示例二:SetForeach(string id, SetType setType, params object[] formatValues)

原始标签:<select id="selClassID"><option value="{0}" >{1}</option></select>

doc.SetForeach("selClassID", SetType.InnerXml,, Class.ID, IsUserLang ? Class.Name : Class.PKey);

结果标签:和上面一样。

示例三:循环格式化:

doc.OnForeach += new XmlHelper.SetForeachEventHandler(Document_OnForeach);

 string Document_OnForeach(string text, object[] values, int row)
 {

  //text为:<option value="{0}" >{1}</option>
           values[0]=“2”;

           values[1]=“标识2”;

           return text;
 }

结果标签:<select id="selClassID"><option value="2">标识2</option>....</select>



新浪微博粉丝精灵,刷粉丝、刷评论、刷转发、企业商家微博营销必备工具"
游客[注册][124.206.31.*]2013/6/11 17:18:15#1
不错

发表评论

论坛公告

    数据框架 CYQ.Data QQ群:6033006
    使用本框架进行开发,入门简单,开发效率高,性能优越,更有详尽的API文档,有相关的使用帮助文章、示例文章、更甚有相关的视频教程及辅助工具。 关键还是免费与开源,实在是居家旅行、项目开发、学习研究的必备良品!!!!!!


    在线帮助:欢迎联系

帖子搜索