本文以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>aaaddd</AlternateText>
<Keyword>aaadd</KeyWord>
<Impressions>98090</Impressions>
</Ad>
<Ad>
<ImageUrl>http://www.aspcn.com/ASPcn.gif</ImageUrl>
<NavigateUrl></NavigateUrl>
<AlternateText>aaasdfasfad</AlternateText>
<Keyword>aaadd</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; file://定義公用的DataSet
DataView dv; file://定義公用的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();
}
}
file://捆綁Binder
public void CreateTable()
{
dgXML.DataSource = dv;
dgXML.DataBind();
}
file://翻頁時
public void dgXML_Changed(Object sender,DataGridPageChangedEventArgs e)
{
CreateTable();
}
file://刪除
public void DelItem(Object sender,DataGridCommandEventArgs e)
{
if(((LinkButton)e.CommandSource).CommandName == "del")
{
file://首先取得當前更新頁的行數與CurrentPageIndex
int CPI = (int)dgXML.CurrentPageIndex;
int EII = (int)e.Item.ItemIndex;
int row = CPI*5+EII;
lb.Text = row.ToString();
file://刪除
dv.Delete(row);
dgXML.EditItemIndex = -1;
ds.WriteXML(sPath);
CreateTable();
}
}
file://取消
public void dgXML_Cancel(Object sender,DataGridCommandEventArgs e)
{
dgXML.EditItemIndex = -1;
CreateTable();
}
file://編輯
public void dgXML_Edit(Object sender,DataGridCommandEventArgs e)
{
dgXML.EditItemIndex = (int)e.Item.ItemIndex;
CreateTable();
}
file://更新
public void dgXML_Update(Object sender, DataGridCommandEventArgs e)
{
try
{
file://首先取得當前更新頁的行數與CurrentPageIndex
int CPI = (int)dgXML.CurrentPageIndex;
int EII = (int)e.Item.ItemIndex;
int row = CPI*5+EII;
file://lb.Text = row.ToString();
file://取得各項值
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" />
<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>
</body>
</Html>
大家好好分析吧。