2011-07-22 62 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