Ã÷»ÔÕ¾/ÍøÕ¾½Ì³Ì/ÄÚÈÝ

XML¡¢DataSet¡¢DataGrid½áºÏд³É¹ã¸æ¹ÜÀí³ÌÐò(¶þ)

ÍøÕ¾½Ì³Ì2024-06-12 ÔĶÁ
[ÕªÒª]Ô´´úÂëÈçÏÂ:<% @ Page Language="C#" ResponseEncoding="gb2312" %><% @ Import Namespace="System.Data" %><% @ Imp...

Ô´´úÂëÈçÏÂ:

<% @ 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>
<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> 

……

Ïà¹ØÔĶÁ