分享
 
 
 

ASP中XML、DataSet、DataGrid结合实例

王朝厨房·作者佚名  2007-01-04
窄屏简体版  字體: |||超大  

本文介绍一下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/10111/pic/20011125_asp_1.jpg" target=_blank>asp/10111/pic/20011125_asp_1s.jpg">

点击看大图

下一节,我们再来看看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>

大家好好分析吧,飞刀要去睡觉啦。天天累成这样子,人都瘦了好多,我好心疼啊......(完)

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有