正在阅读:ASP中XML、DataSet、DataGrid结合实例ASP中XML、DataSet、DataGrid结合实例

2004-02-14 09:33 出处:ASPCN 作者:飞刀 责任编辑:pjl
  本文介绍一下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的源代码 上一节中,由于XML文件占了很大的篇幅,只好把源程序贴在这一页了。 也是很长的哟,大家有性子看才行:) <% @ Page Language="C#" ResponseEncoding="gb2312" %> <% @ Import Namespace="System.Data" %> <% @ Import Namespace="System.Xml" %> <% @ Import Namespace="System.IO" %> <Script Language="C#" Runat="Server"> DataSet ds; //定义公用的DataSet DataView dv; //定义公用的DataView string 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(); } } //捆绑Binder public 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> <head> <title></title> </head> <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" /> <asp: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> 大家好好分析吧,飞刀要去睡觉啦。天天累成这样子,人都瘦了好多,我好心疼啊......(完)

关注我们

最新资讯离线随时看 聊天吐槽赢奖品