2011-07-22 65 views
0

我試圖從xml文件以編程方式爲我的網站創建一個菜單。 該菜單在菜單欄中有三個鏈接,可以在鼠標懸停事件上展開, 可顯示內容(鏈接和圖像)。 xml文件具有MenuItem節點,其中 對應於菜單欄中的三個鏈接以及與內容上的鼠標對應的MenuContent節點。在僞代碼中,以下是我想要的 :LINQ到XML分組

  1. 閱讀xml文件。
  2. 通過MenuItem節點對xml文件進行分組。
  3. 用MenuItem數據填充外部中繼器。
  4. 對於每個MenuItem節點,使用MenuContent數據填充內部中繼器。

我的問題是,我不知道如何正確組中的菜單項節點和 然後填充內轉發。用於分組的C#代碼是 在較早的項目中工作的,但在這種情況下不起作用。我只是把它包括到 得到一些代碼。

我該如何修改C#代碼以由MenuItem 節點進行分組並填充內部中繼器?

<asp:Repeater ID="Repeater1" runat="server"> 
    <ItemTemplate> 
     <div> 
      <asp:Repeater ID="Repeater2" runat="server"> 
       <ItemTemplate> 
        <div class="menuContent"> 
         <div> 
          <div class="menuContentItem"> 
           <a href='<%# Eval("LinkUrl") %>'> 
            <table> 
             <tr> 
              <td align="center" valign="middle"> 
               <img src='<%# Eval("ImageUrl") %>' alt='<%# Eval("ImageToolTip") %>' /> 
              </td> 
              <td align="left" valign="top"> 
               <div><%# Eval("Title") %></div> 
               <div><%# Eval("Description") %></div> 
              </td> 
             </tr> 
            </table> 
           </a> 
          </div> 
         </div> 
        </div> 
       </ItemTemplate> 
      </asp:Repeater> 
     </div> 
    </ItemTemplate> 
</asp:Repeater> 


var menuPath = Server.MapPath("~/Menu.xml"); 
var xDocument = XDocument.Load(menuPath); 
var menuItems = new List<MenuItem>(); 

var groups = (from x in xDocument.XPathSelectElements("Menu") 
       group x by new 
       { 
        Description = x.Descendants("Description").FirstOrDefault().Value, 
        ImageToolTip = x.Descendants("ImageToolTip").FirstOrDefault().Value, 
        ImageUrl = x.Descendants("ImageUrl").FirstOrDefault().Value, 
        LinkUrl = x.Descendants("LinkUrl").FirstOrDefault().Value, 
        Title = x.Descendants("Title").FirstOrDefault().Value 
       } into g 
       select g).ToDictionary(g => g.Key, g => g.ToArray()); 


Repeater1.DataSource = groups; 
Repeater1.DataBind(); 



<?xml version="1.0" encoding="utf-8" ?> 

<Menu> 
    <MenuItem> 
     <MenuContent> 
      <Title>Title 1a</Title> 
      <Description>Description 1a</Description> 
      <LinkUrl>Link URL 1a</LinkUrl> 
      <ImageUrl>Image URL 1a</ImageUrl> 
      <ImageToolTip>Image ToolTip 1a</ImageToolTip> 
     </MenuContent> 
     <MenuContent> 
      <Title>Title 2a</Title> 
      <Description>Description 2a</Description> 
      <LinkUrl>Link URL 2a</LinkUrl> 
      <ImageUrl>Image URL 2a</ImageUrl> 
      <ImageToolTip>Image ToolTip 2a</ImageToolTip> 
     </MenuContent> 
     <MenuContent> 
      <Title>Title 3a</Title> 
      <Description>Description 3a</Description> 
      <LinkUrl>Link URL 3a</LinkUrl> 
      <ImageUrl>Image URL 3a</ImageUrl> 
      <ImageToolTip>Image ToolTip 3a</ImageToolTip> 
     </MenuContent> 
    </MenuItem> 
    <MenuItem> 
     <MenuContent> 
      <Title>Title 1b</Title> 
      <Description>Description 1b</Description> 
      <LinkUrl>Link URL 1b</LinkUrl> 
      <ImageUrl>Image URL 1b</ImageUrl> 
      <ImageToolTip>Image ToolTip 1b</ImageToolTip> 
     </MenuContent> 
     <MenuContent> 
      <Title>Title 2b</Title> 
      <Description>Description 2b</Description> 
      <LinkUrl>Link URL 2b</LinkUrl> 
      <ImageUrl>Image URL 2b</ImageUrl> 
      <ImageToolTip>Image ToolTip 2b</ImageToolTip> 
     </MenuContent> 
     <MenuContent> 
      <Title>Title 3b</Title> 
      <Description>Description 3b</Description> 
      <LinkUrl>Link URL 3b</LinkUrl> 
      <ImageUrl>Image URL 3b</ImageUrl> 
      <ImageToolTip>Image ToolTip 3b</ImageToolTip> 
     </MenuContent> 
    </MenuItem> 
</Menu> 

回答

4

而不是使用聚合的,你可以嘗試以下方法:

var groups = from x in xd.Element("Menu").Elements("MenuItem") 
      select new 
      { 
       Items = (from c in x.Elements("MenuContent") 
          select new 
          { 
           Description = c.Element("Description").Value, 
           ImageToolTip = c.Element("ImageToolTip").Value, 
           ImageUrl = c.Element("ImageUrl").Value, 
           LinkUrl = c.Element("LinkUrl").Value, 
           Title = c.Element("Title").Value 
          }).ToList() 
      }; 

然後Repeater2標籤更改爲:

<asp:Repeater ID="Repeater2" DataSource='<%# Eval("Items") %>' runat="server"> 
+0

完美!正是我需要做的!非常感謝! – Halcyon