最近小弟做了个xml加.net的程序,但是不知道如何把查询的xml数据显示到datalist中,请高手给予指点。
解决方案 »
- 无法在此路径使用此配置节。当站点管理员使用继承的配置文件中的 <location allowOverride="false"> 锁定对此节的访问时会出现这种情况
- ASP.NET创建cookie为什么生成不了文件?
- discuzNT论坛 的问题
- 求一个asp.net显示一篇文章的方法?
- repeater中动态创建的checkboxlist或是radioboxlist取值,在线等。解决立即给分。
- Panel的使用问题,请教各位高手!!!!!!
- <asp:CheckBox 全选问题????
- .net怎行生成ppt文档
- 请问,如何将xml文件中部分数据读取成为DATASET 100分
- 菜鸟问题,见笑了。
- onload="javascript:this.style.width=window.screen.width; 火狐下无效,怎么解决
- 问一下vs2008网站发布的问题
<?xml version="1.0" encoding="gb2312"?>
<Photos_Sorts>
<Sort>
<Name>极杜空间</Name>
<Commentary>极杜空间的相册</Commentary>
<Commended_Degree>5</Commended_Degree>
</Sort>
<Sort>
<Name>杜威</Name>
<Commentary>杜威的相册</Commentary>
<Commended_Degree>4</Commended_Degree>
</Sort>
<Sort>
<Name>搜狐</Name>
<Commentary>搜狐的相册</Commentary>
<Commended_Degree>3</Commended_Degree>
</Sort>
<Sort>
<Name>Sohu</Name>
<Commentary>Sohu'Album</Commentary>
<Commended_Degree>5</Commended_Degree>
</Sort>
</Photos_Sorts>节点说明:Name(相册名称),Commentary(相册说明),Commended_Degree(推荐度)二.下面新建的Web页面(AlbumList.aspx)
在该页面中放置一个DataList控件,并命名为“dlAlbums”,在设计视图中右击DataList控件选择编辑模版->编辑项模版->右击DataList控件->结束模版编辑->再右击DataList控件->属性生成器->“常规”->“列”值为4->“方向”水平->"布局"表->“确定"完成设置。设置好后DataList控件HTML代码如下显示<asp:DataList id="DataList1" style="Z-INDEX: 101; LEFT: 352px; POSITION: absolute; TOP: 128px"
runat="server" RepeatDirection="Horizontal">
<ItemTemplate>
相册名称:
<asp:Label id="lblAlbumName" runat="server"></asp:Label><br />
相册说明:
<asp:Label id="lblAlbumCommentary" runat="server"></asp:Label><br />
推荐度:
<asp:Label id="lblAlbumCommended_Degree" runat="server"></asp:Label><br />
</ItemTemplate>
</asp:DataList>三.为DataList中的Label控件设置绑定数据 红色字体为绑定设置,注意书写的格式。DataBinder.Eval(Container.DataItem,"***")语句中的引号中的为字段名,主要要与XML中需要绑定的节点同名。<asp:DataList id="dlAlbums" runat="server" RepeatDirection="Horizontal" Width="736px" Height="152px">
<ItemTemplate>
相册名称:
<asp:Label id="lblAlbumName" runat="server" Text='<%#DataBinder.Eval(Container.DataItem,"Name")%>'>
</asp:Label><br />
相册说明:
<asp:Label id="lblAlbumCommentary" runat="server" Text='<%#DataBinder.Eval(Container.DataItem,"Commentary")%>'>
</asp:Label><br />
推荐度:
<asp:Label id="lblAlbumCommended_Degree" runat="server" Text='<%#DataBinder.Eval(Container.DataItem,"Commended_Degree")%>'>
</asp:Label><br />
</ItemTemplate>
</asp:DataList>四.后台代码文件AlbumList.aspx.cs中添加下列绑定数据的方法。 /// <summary>
/// 绑定相册数据
/// </summary>
private void AlbumsBind()
{
//获取Photos_Sorts.xml的地址,假定Photos_Sorts.xml存在应用程序根目录下
string Path = Server.MapPath(Request.ApplicationPath)+"\\Photos_Sorts.xml";
//实例化DataSet
System.Data.DataSet XMLDataSet = new DataSet();
//读取XML文档
XMLDataSet.ReadXml(Path);
//设置DataList数据源,注意选择的是DataSet中的表“Sort”。
dlAlbums.DataSource = XMLDataSet.Tables["Sort"];
dlAlbums.DataBind();
}
在Page_Load()中添加AlbumsBind()。private void Page_Load(object sender, System.EventArgs e){
// 在此处放置用户代码以初始化页面
if(!Page.IsPostBack)
{
AlbumsBind();
} }
參考 很全
这里,然后跟居参数查出相应的xml数据显示到datalist中
<product>
<pname>座便器</pname>
<plogo>亚陶卫浴</plogo>
<purl>tgbuys.aspx</purl>
<pimg>products/3398-A.jpg</pimg>
<priold>2680</priold>
<prinow>1元起拍</prinow>
<dw>元/个</dw>
<say>以现场最终拍卖价为准</say>
</product>
<product>
<pname>瓷砖</pname>
<plogo>福布斯</plogo>
<purl>tgbuys.aspx</purl>
<pimg>products/45008.jpg</pimg>
<priold>16.8</priold>
<prinow>4.5</prinow>
<dw>元/片</dw>
<say>此砖为团购价,数量有限,要抓紧时间抢购。</say>
</product>
<product>
<pname>集成环保灶F1</pname>
<plogo>福腾宝</plogo>
<purl>tgbuys.aspx</purl>
<pimg>products/fbtf1.jpg</pimg>
<priold>7880</priold>
<prinow>4880</prinow>
<dw>元/个</dw>
<say>集成环保灶,油烟净化率99%以上。请朋友们现场抓紧抢购!</say>
</product>
</products>
比如搜索瓷砖就把xml中<pname>为瓷砖的显示datalist中,搜索集成环保灶,datalist中就只显示环保灶相关的数据。
void Main()
{
//使用session来传参
// string xml=Session["xml"].ToString();
//下边的xml是举例子的:
string xml = @"<products>
<product>
<pname>座便器</pname>
<plogo>亚陶卫浴</plogo>
<purl>tgbuys.aspx</purl>
<pimg>products/3398-A.jpg</pimg>
<priold>2680</priold>
<prinow>1元起拍</prinow>
<dw>元/个</dw>
<say>以现场最终拍卖价为准</say>
</product>
<product>
<pname>瓷砖</pname>
<plogo>福布斯</plogo>
<purl>tgbuys.aspx</purl>
<pimg>products/45008.jpg</pimg>
<priold>16.8</priold>
<prinow>4.5</prinow>
<dw>元/片</dw>
<say>此砖为团购价,数量有限,要抓紧时间抢购。</say>
</product>
<product>
<pname>集成环保灶F1</pname>
<plogo>福腾宝</plogo>
<purl>tgbuys.aspx</purl>
<pimg>products/fbtf1.jpg</pimg>
<priold>7880</priold>
<prinow>4880</prinow>
<dw>元/个</dw>
<say>集成环保灶,油烟净化率99%以上。请朋友们现场抓紧抢购!</say>
</product>
</products>";
XElement xmlPage = XElement.Parse(xml);
var q = from x in xmlPage.Descendants("product")
where x.Element("pname").Value == "瓷砖"
select x;
q.ToList().ForEach(m=>Console.WriteLine(m.Value));
}
//瓷砖福布斯tgbuys.aspxproducts/45008.jpg16.84.5元/片此砖为团购价,数量有限,要抓紧时间抢购。
后边如何绑定到datalist上
我想你应该会的