bob体育官方平台
xml 封装与解析_javascript技巧_脚本之家

1.xml的解析: 具体代码如下,解析的结果root为Dom树。 复制代码 代码如下: if { var doc=new ActiveXObject; doc.async="false"; doc.loadXML; }else{ var parser=new DOMParser(); var doc=parser.parseFromString; } var root = doc.documentElement; 2.xml的封装: (该代码为将页面中table封装为一个xml) 复制代码 代码如下: var xmlDoc = new ActiveXObject; xmlDoc.loadXML; var root = xmlDoc.documentElement; for(var index=0;index3.xml的封装: 具体方法如下, 复制代码 代码如下: XmlDocument doc = new XmlDocument(); doc.LoadXml; XmlElement root = doc.DocumentElement; root.SetAttribute;//此处name为该xml赋一个Name属性 foreach (ListObject Object in ListResult)//其中listResult为一个由listObject对象组成的list表,其中object为listResult的一个元素,他是ListObject型的 { XmlElement item = doc.CreateElement; item.SetAttribute;//其中key,value分别为Object的属性元素 item.SetAttribute("Value", Object.Value); root.AppendChild; } 最后生成的root即为xml. 4.xml的解析 复制代码 代码如下: XmlDocument doc = new XmlDocument(); try { doc.Load;//此处加载request请求的xml流 } catch {} XmlNodeList rowList; rowList = doc.DocumentElement.SelectNodes; List voList = new List;//初始化一个List,改list中组成元素是ObjectVO对象 foreach (XmlNode row in rowList) { ObjectVO VO = new ObjectVO(); VO.VOElement1 = Convert.ToInt32((row.SelectSingleNode("Cell[@Name='VOElement1']") as XmlElement).GetAttribute;//vo中元素VOElement1为int型 VO.VOElement2 = (row.SelectSingleNode("Cell[@Name='VOElement2']") as XmlElement).GetAttribute;//或取xml中cell元素中name为VOElement2的value属性的值 VO.VOElement3 = (row.SelectSingleNode("Cell[@Name='VOElement3']") as XmlElement).GetAttribute; voList.Add; } return voList;

1.xml的解析(javascript中):
具体代码如下,解析的结果root为Dom树。

XML文件是一种常用的文件格式,例如WinForm里面的app.config以及Web程序中的web.config文件,还有许多重要的场所都有它的身影。Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具。XML是一种简单的数据存储语言,使用一系列简单的标记描述数据,而这些标记可以用方便的方式建立,虽然XML占用的空间比二进制数据要占用更多的空间,但XML极其简单易于掌握和使用。微软也提供了一系列类库来倒帮助我们在应用程序中存储XML文件。

复制代码 代码如下:

“在程序中访问进而操作XML文件一般有两种模型,分别是使用DOM和流模型,使用DOM的好处在于它允许编辑和更新XML文档,可以随机访问文档中的数据,可以使用XPath查询,但是,DOM的缺点在于它需要一次性的加载整个文档到内存中,对于大型的文档,这会造成资源问题。流模型很好的解决了这个问题,因为它对XML文件的访问采用的是流的概念,也就是说,任何时候在内存中只有当前节点,但它也有它的不足,它是只读的,仅向前的,不能在文档中执行向后导航操作。”具体参见在Visual C#中使用XML指南之读取XML

if (window.ActiveXObject){
var doc=new ActiveXObject("Microsoft.XMLDOM");
doc.async="false";
doc.loadXML(strXml);
}else{
var parser=new DOMParser();
var doc=parser.parseFromString(strXml,"text/xml");
}
var root = doc.documentElement;

下面我将介绍三种常用的读取XML文件的方法。分别是
1: 使用XmlDocument
2: 使用 XmlTextReader

2.xml的封装(javascript中): (该代码为将页面中table封装为一个xml)

3: 使用 Linq to Xml

复制代码 代码如下:

下面我们使用XmlDocument:

var xmlDoc = new ActiveXObject("Microsoft.XMLDOM");
xmlDoc.loadXML("<Rows></Rows>");
var root = xmlDoc.documentElement;
for(var index=0;index<this.table.rows.length;index++)
{
var row = xmlDoc.createElement("Row");
for(var colIndex = 0;colIndex<this.table.rows[index].cells.length;colIndex++)
{
var currentCell = this.table.rows[index].cells[colIndex];
var cell = xmlDoc.createElement("Cell");
cell.setAttribute("Name",this.table.columns[colIndex].id);
cell.setAttribute("Value",currentCell.value);
row.appendChild(cell);
}
root.appendChild(row);
}

1.读取元素和属性:

对于ajax实现前台xml到后台的传输可以参考jquery实现xml的前后台传输。
3.xml的封装:(C#)
具体方法如下,

XmlDocument doc = new XmlDocument();

复制代码 代码如下:

doc.Load("Customer2.xml");
List<CustomerInfo> lists = new List<CustomerInfo>();

XmlDocument doc = new XmlDocument();
doc.LoadXml("<Data></Data>");
XmlElement root = doc.DocumentElement;
root.SetAttribute("Name", name);//此处name为该xml赋一个Name属性
foreach (ListObject Object in ListResult)//其中listResult为一个由listObject对象组成的list表,其中object为listResult的一个元素,他是ListObject型的
{
XmlElement item = doc.CreateElement("Item");
item.SetAttribute("Key", Object.key);//其中key,value分别为Object的属性元素
item.SetAttribute("Value", Object.Value);
root.AppendChild(item);
}

XmlNodeList list = doc.SelectNodes("/Table/row");

最后生成的root即为xml.
4.xml的解析(c#)

foreach (XmlNode item in list)
{
CustomerInfo cust = new CustomerInfo();
cust.Version = item.Attributes["Version"].Value;
cust.AppId = item.Attributes["AppId"].Value;
cust.CustomerID = item["CustomerID"].InnerText;
cust.CompanyName = item["CompanyName"].InnerText;
cust.ContactName = item["ContactName"].InnerText;
cust.ContactTitle = item["ContactTitle"].InnerText;
cust.Address = item["Address"].InnerText;
cust.City = item["City"].InnerText;
cust.PostalCode = item["PostalCode"].InnerText;
cust.Country = item["Country"].InnerText;
cust.Phone = item["Phone"].InnerText;
cust.Fax = item["Fax"].InnerText;
lists.Add;

复制代码 代码如下:

}

XmlDocument doc = new XmlDocument();
try
{
doc.Load(Request.InputStream);//此处加载request请求的xml流
}
catch (Exception e)
{}
XmlNodeList rowList;
rowList = doc.DocumentElement.SelectNodes("Row");
List<ObjectVO> voList = new List<ObjectVO>(rowList.Count);//初始化一个List,改list中组成元素是ObjectVO对象
foreach (XmlNode row in rowList)
{
ObjectVO VO = new ObjectVO();
VO.VOElement1 = Convert.ToInt32((row.SelectSingleNode("Cell[@Name='VOElement1']") as XmlElement).GetAttribute("Value"));//vo中元素VOElement1为int型
VO.VOElement2 = (row.SelectSingleNode("Cell[@Name='VOElement2']") as XmlElement).GetAttribute("Value").ToString();//或取xml中cell元素中name为VOElement2的value属性的值
VO.VOElement3 = (row.SelectSingleNode("Cell[@Name='VOElement3']") as XmlElement).GetAttribute("Value").ToString();
voList.Add(VO);
}
return voList;

2.创建文档-属性和元素

具体代码如下,解析的结果root为Dom树。 复制代码 代码如下: if (window.ActiveXObject){ var doc=new ActiveXObject("Microsoft.X...

XmlDocument doc = new XmlDocument();
// doc.Load("Customertest1.xml");

XmlDeclaration xmldecl = doc.CreateXmlDeclaration("1.0", "utf-8", null);
XmlElement root = doc.DocumentElement;
doc.InsertBefore(xmldecl, root);

XmlElement ele = doc.CreateElement;
doc.AppendChild;

返回顶部