最近小弟做了个xml加.net的程序,但是不知道如何把查询的xml数据显示到datalist中,请高手给予指点。

解决方案 »

  1.   

    一.相册文件所需要的XML文件如下:(Photos_Sorts.xml)
    <?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();
       } }
    參考 很全
      

  2.   

    非常感谢一楼老兄的回答,但是这只是读取xml文档绑定到datalis中,我想要的是比如另外一个页面传参数到
    这里,然后跟居参数查出相应的xml数据显示到datalist中
      

  3.   

    <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>
    比如搜索瓷砖就把xml中<pname>为瓷砖的显示datalist中,搜索集成环保灶,datalist中就只显示环保灶相关的数据。
      

  4.   


    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元/片此砖为团购价,数量有限,要抓紧时间抢购。
      

  5.   

    值都取出来了
    后边如何绑定到datalist上
     我想你应该会的
      

  6.   

    果然是高手,能不能把绑定到datalist的代码也给一下,小弟对绑定xml还不太懂啦。