现在的位置: 首页 >> 网站编程 >> ASP.NET >> 用ASP.NET结合XML制作广告管理程序
添加时间:2005-10-30 来源:网教中国 作者:
用ASP.NET结合XML制作广告管理程序

  中文有点问题,但是在下面的程序中可以正常显示的,因为用了国际化技术,哈哈,这个例子用的东东可不少哟:

  这是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>



上一页 [1] [2] [3]  下一页


上一篇:用ASP.NET写你自己的代码生成器 下一篇:ASP.NET中实时图表的实现
大部分文章摘自网上,如有侵犯您的权益请与我们联系,我们会第一时间进行处理,谢谢! [ 打印文章 ] [ 关闭窗口 ]
推荐文章
·ASP.NET 2.0中构造个性化网页
·利用 ASP.NET 的内置功能抵御 We
·提高ASP.Net应用程序性能的十大(
·不用SQL语句查询DataTable中的数
·基于C#的接口基础教程之六(5)
·ASP.NET应用程序规划与设计(1)
·ASP.NET可交互式位图窗体设计(5)
·ASP.NET虚拟主机的重大安全隐患(
·在网页中动态的生成一个gif图片
·改写即时消息的发送,包含同时给
相关文章
 
最新文章
·《ASP.NET网站建设专家》目录
·《ASP.NET网站建设专家》前言
·用ASP.NET在同一网页中显示主从
·ASP.NET 如何操作文件
·ASP.NET 2.0中构造个性化网页
·利用 ASP.NET 的内置功能抵御 We
·.text urlRewrite介绍
·ASP.NET中为DataGrid添加合计字
·用 WebClient.UploadData 方法
·ASP.NET Cache
Google