本文介绍一下ASP.Net中对XML的用法,这里只是展现了XML与DataSet相结合的用法。其实ASP.Net对XML的操作的方法与对象是很多的,比如XmlDataDocument,XmlTextReader等,这些对象功能很全,也很实用。
本文以Adrotator控件使用的XML为例(新手可以先看一下Adrotator控件的用法),写出了一个广告管理程序。这个程序,飞刀用到的控件主要是DataGrid,可以说已经用到了DataGrid几乎全部功能,大家在关注XML的同时,可以同时学到DataGrid使用方法。
先将本例中使用的一些方法对大家说明一下:
DataSet主要是使用的ReadXml与WriteXml方法。它们的功能看名字就知道了,飞刀也不罗嗦了。 DataGrid中使用的了很多的方法和对象。比如分页使用AllowPaging属性,排序使用AllowSorting属性,本例中使用了所有DataGrid中的事件,比如OnItemCommand,OnEditCommand,OnCancelCommand,OnUpdateCommand等。
大家认真查看这些事件的处理。
另外大家在看程序时,再想想,如果这个程序使用ASP来写需要多少页,呵呵,用ASP.Net只需要一页,而且无限次使用,这就是ASP.Net的优点。
程序中飞刀我做了些简单的注释,最重要的还是大家的理解。
呵呵,最近我们工作室的人是忙得一踏糊涂,所以就请大家原谅啦。飞刀这些日子不是不写程序,只是写的程序都需要发表在书上,(比如和追捕软件一样功能的Web网页啦,真的可以实现与追捕一样的功能,绝无虚假)不能贴在网上啦。这样会被骂的:)
先看看我们操作的XML文件的内容: <?xml version="1.0" standalone="yes"?><Advertisements>
<xsd:schema id="Advertisements" targetNamespace="" xmlns=""
xmlns:xsd="http://www.w3.org/1999/XMLSchema"
xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
<xsd:element name="Ad">
<xsd:complexType content="elementOnly">
<xsd:all>
<xsd:element name="ImageUrl" minOccurs="0" type="xsd:string"/>
<xsd:element name="NavigateUrl" minOccurs="0" type="xsd:string"/>
<xsd:element name="AlternateText" minOccurs="0" type="xsd:string"/>
<xsd:element name="Keyword" minOccurs="0" type="xsd:string"/>
<xsd:element name="Impressions" minOccurs="0" type="xsd:string"/>
</xsd:all>
</xsd:complexType>
</xsd:element>
<xsd:element name="Advertisements" msdata:IsDataSet="True">
<xsd:complexType>
<xsd:choice maxOccurs="unbounded">
<xsd:element ref="Ad"/>
</xsd:choice>
</xsd:complexType>
</xsd:element>
</xsd:schema>
<Ad>
<ImageUrl>aspcn_bbs1.gifc</ImageUrl>
<NavigateUrl>http://www.aspcn.com/bbs</NavigateUrl>
<AlternateText>ASPCN?€?????/AlternateText>
<Keyword>bbs</Keyword>
<Impressions>50</Impressions>
</Ad>
<Ad>
<ImageUrl>aspcn_bbs3.gif</ImageUrl>
<NavigateUrl>http://www.aspcn.com/bbs</NavigateUrl>
<AlternateText>ASPCN?€?????/AlternateText>
<Keyword>bbs</Keyword>
<Impressions>50</Impressions>
</Ad>
<Ad>
<ImageUrl>aspcn_bbs2.gifc</ImageUrl>
<NavigateUrl>http://www.aspcn.com/bbs</NavigateUrl>
<AlternateText>ASPCN?€?????/AlternateText>
<Keyword>bbs2</Keyword>
<Impressions>50</Impressions>
</Ad>
<Ad>
<ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl>
<NavigateUrl>http://www.aspcn.com</NavigateUrl>
<AlternateText>???涓??浜?/AlternateText>
<Keyword>涓??浜?/Keyword>
<Impressions>80</Impressions>
</Ad>
<Ad>
<ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl>
<NavigateUrl>http://www.aspcn.com</NavigateUrl>
<AlternateText>???涓??浜?/AlternateText>
<Keyword>涓??浜?/Keyword>
<Impressions>80</Impressions>
</Ad>
<Ad>
<ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl>
<NavigateUrl>http://www.aspcn.com</NavigateUrl>
<AlternateText>???涓??浜?/AlternateText>
<Keyword>涓??浜?/Keyword>
<Impressions>80</Impressions>
</Ad>
<Ad>
<ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl>
<NavigateUrl>http://www.aspcn.com</NavigateUrl>
<AlternateText>???涓??浜?/AlternateText>
<Keyword>涓??浜?/Keyword>
<Impressions>80</Impressions>
</Ad>
<Ad>
<ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl>
<NavigateUrl>http://www.aspcn.com</NavigateUrl>
<AlternateText>???涓??浜?/AlternateText>
<Keyword>涓??浜?/Keyword>
<Impressions>80</Impressions>
</Ad>
<Ad>
<ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl>
<NavigateUrl>http://www.aspcn.com</NavigateUrl>
<AlternateText>???涓??浜?/AlternateText>
<Keyword>涓??浜?/Keyword>
<Impressions>80</Impressions>
</Ad>
<Ad>
<ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl>
<NavigateUrl>http://www.aspcn.com</NavigateUrl>
<AlternateText>???涓??浜?/AlternateText>
<Keyword>涓??浜?/Keyword>
<Impressions>80</Impressions>
</Ad>
<Ad>
<ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl>
<NavigateUrl>http://www.aspcn.com</NavigateUrl>
<AlternateText>???涓??浜?/AlternateText>
<Keyword>涓??浜?/Keyword>
<Impressions>80</Impressions>
</Ad>
<Ad>
<ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl>
<NavigateUrl>http://www.aspcn.com</NavigateUrl>
<AlternateText>???涓??浜?/AlternateText>
<Keyword>涓??浜?/Keyword>
<Impressions>80</Impressions>
</Ad>
<Ad>
<ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl>
<NavigateUrl>http://www.aspcn.com</NavigateUrl>
<AlternateText>???涓??浜轰ddd</AlternateText>
<Keyword>涓??浜轰dd</Keyword>
<Impressions>98090</Impressions>
</Ad>
<Ad>
<ImageUrl>http://www.aspcn.com/aspcn.gif</ImageUrl>
<NavigateUrl></NavigateUrl>
<AlternateText>???涓??浜横sdfasfad</AlternateText>
<Keyword>涓??浜轰dd</Keyword>
<Impressions>98090</Impressions>
</Ad>
<Ad>
<ImageUrl>http://wwwaspcn.com</ImageUrl>
<NavigateUrl>http://</NavigateUrl>
<AlternateText></AlternateText>
<Keyword></Keyword>
<Impressions></Impressions></Ad></Advertisements>
中文有点问题,但是在下面的程序中可以正常显示的,因为用了国际化技术,哈哈,这个例子用的东东可不少哟:)
这是Adrotator控件引用的标准格式XML。
我们先来看看程序的最后的显示结果是什么
我们再来看看ASP.Net的源代码 <% @ Page Language="C#" ResponseEncoding="gb2312" %><% @ Import Namespace="System.Data" %><% @ Import Namespace="System.Xml" %><% @ Import Namespace="System.IO" %><Script Language="C#" Runat="Server">DataSet ds;
//定义公用的DataSetDataView dv;
//定义公用的DataViewstring SortField;string sPath;public void Page_Load(Object src,EventArgs e){
if(State["adxml"]==null)
{
sPath = Server.MapPath(".") + "\AdBanners\ad_gb.xml";
ds = new DataSet();
ds.ReadXml(sPath);
State["adxml"] = ds;
}
else
{
ds = (DataSet)State["adxml"];
}
dv = ds.Tables[0].DefaultView;
dv.Sort = "ImageUrl";
if(!Page.IsPostBack)
{
CreateTable();
}}//捆绑Binderpublic void CreateTable(){
dgXML.DataSource = dv;
dgXML.DataBind();}//翻页时public void dgXML_Changed(Object sender,DataGridPageChangedEventArgs e){
CreateTable();}//删除public void DelItem(Object sender,DataGridCommandEventArgs e){
if(((LinkButton)e.CommandSource).CommandName == "del")
{
//首先取得当前更新页的行数与CurrentPageIndex
int CPI = (int)dgXML.CurrentPageIndex;
int EII = (int)e.Item.ItemIndex;
int row = CPI*5+EII;
lb.Text = row.ToString();
//删除
dv.Delete(row);
dgXML.EditItemIndex = -1;
ds.WriteXml(sPath);
CreateTable();
}}//取消public void dgXML_Cancel(Object sender,DataGridCommandEventArgs e){
dgXML.EditItemIndex = -1;
CreateTable();}//编辑public void dgXML_Edit(Object sender,DataGridCommandEventArgs e){
dgXML.EditItemIndex = (int)e.Item.ItemIndex;
CreateTable();}//更新public void dgXML_Update(Object sender, DataGridCommandEventArgs e){
try
{
//首先取得当前更新页的行数与CurrentPageIndex
int CPI = (int)dgXML.CurrentPageIndex;
int EII = (int)e.Item.ItemIndex;
int row = CPI*5+EII;
//lb.Text = row.ToString();
//取得各项值
string ImageUrl
= ((TextBox)e.Item.Cells[2].Controls[0]).Text;
string NavigateUrl
= ((TextBox)e.Item.Cells[3].Controls[0]).Text;
string AlternateText
= ((TextBox)e.Item.Cells[4].Controls[0]).Text;
string Keyword
= ((TextBox)e.Item.Cells[5].Controls[0]).Text;
string Impressions
= ((TextBox)e.Item.Cells[6].Controls[0]).Text;
dv.Delete(row);
DataRow dr = ds.Tables[0].NewRow();
dr[0]
=
ImageUrl;
dr[1]
=
NavigateUrl;
dr[2]
=
AlternateText;
dr[3]
=
Keyword;
dr[4]
=
Impressions;
ds.Tables[0].Rows.Add(dr);
ds.WriteXml(sPath);
}
catch(Exception ee)
{
lb.Text = ee.ToString();
}
dgXML.EditItemIndex = -1;
CreateTable();}public void PanelShow(Object sender,EventArgs e){
AddItem.Visible = true;}public void AddItem_Click(Object sender,EventArgs e){
DataRow dr = ds.Tables[0].NewRow();
dr[0]
=
mUrl.Text;
dr[1]
=
aUrl.Text;
dr[2]
=
mText.Text;
dr[3]
=
aKey.Text;
dr[4]
=
aTime.Text;
ds.Tables[0].Rows.Add(dr);
ds.WriteXml(sPath);
CreateTable();
AddItem.Visible=false;}</script><html><head><title></title></head><body><form id="form1" runat="server"><asp:DataGrid id="dgXML" runat="server"AllowPaging="True"PageSize="10"BorderColor="black"BorderWidth="1"CellPadding="3"Font-Name="Verdana"Font-Size="8pt"HeaderStyle-BackColor="#aaaadd"PagerStyle-Mode="NumericPages"PagerStyle-HorizontalAlign="Right"PagerStyle-PrevPageText="前页"PagerStyle-NextPageText="后页"OnPageIndexChanged="dgXML_Changed"OnEditCommand="dgXML_Edit"OnCancelCommand="dgXML_Cancel"OnUpdateCommand="dgXML_Update"OnItemCommand="DelItem"AutoGenerateColumns="false"><property name="Columns">
<asp:ButtonColumn HeaderText="删除" Text="删除" CommandName="del" />
。坚sp:EditCommandColumn EditText="修改" CancelText="取消" UpdateText="更新" ItemStyle-Wrap="false" HeaderText="操作区" HeaderStyle-Wrap="false" />
<asp:BoundColumn HeaderText="图片地址(相对)" SortField="ImageUrl" DataField="ImageUrl" />
<asp:BoundColumn HeaderText="链接URL" SortField="NavigateUrl" DataField="NavigateUrl" />
<asp:BoundColumn HeaderText="图片说明" SortField="AlternateText" DataField="AlternateText" />
<asp:BoundColumn HeaderText="类别" SortField="Keyword" DataField="Keyword" />
<asp:BoundColumn HeaderText="显示时间" SortField="Impressions" DataField="Impressions" /></property></asp:DataGrid><hr><asp:Button id="vi" Text="添加新项" OnClick="PanelShow" runat="server"/><br><asp:Panel id="AddItem" runat="server" Visible="false"><table>
<tr Bgcolor="#aaaadd"><td colspan=2>添加新的广告页面</td></tr>
<tr>
<td>广告图片URL:</td>
<td><asp:TextBox id="mUrl" runat="server" Text="http://" /></td>
</tr>
<tr>
<td>广告链接地址:</td>
<td><asp:TextBox id="aUrl" runat="server" Text="http://" /></td>
</tr>
<tr>
<td>图片说明:</td>
<td><asp:TextBox id="mText" runat="server" /></td>
</tr>
<tr>
<td>广告所属类别:</td>
<td><asp:TextBox id="aKey" runat="server" /></td>
</tr>
<tr>
<td>显示时间</td>
<td><asp:TextBox id="aTime" runat="server" /></td>
</tr>
<tr><td>
<asp:Button id="submit" Text="提交" OnClick="AddItem_Click" runat="server" /></td></tr></table></asp:Panel><asp:Label id="lb" runat="server" /></form></body></html>