先来张图片说明下我们要实现的菜单:

这个菜单只实现了2级哈。

我采用的方法是嵌套2个Repeater。

先看下数据库中的表结构:

数据:

上代码:

aspx:

  1. <asp:Repeater ID="rptMenus" runat="server"
  2. onitemdatabound="rptMenus_ItemDataBound">
  3. <HeaderTemplate>
  4. <ul class="mnuLevel01">
  5. <li id="mnuHome"><a href="#">首页</a></li>
  6. </HeaderTemplate>
  7. <ItemTemplate>
  8. <li class="multiItem">
  9. <a target="<%#DataBinder.Eval(Container.DataItem,"target") %>" href="<%#DataBinder.Eval(Container.DataItem,"Url") %>"><%#DataBinder.Eval(Container.DataItem,"Title") %></a>
  10. <asp:Repeater ID="rptSubMenus" runat="server">
  11. <HeaderTemplate>
  12. <ul class="mnuLevel02">
  13. </HeaderTemplate>
  14. <ItemTemplate>
  15. <li><a href="<%#DataBinder.Eval(Container.DataItem,"Url") %>"><%#DataBinder.Eval(Container.DataItem,"Title") %></a></li>
  16. </ItemTemplate>
  17. <FooterTemplate>
  18. </ul>
  19. </FooterTemplate>
  20. </asp:Repeater>
  21. </li>
  22. </ItemTemplate>
  23. <FooterTemplate>
  24. </ul>
  25. </FooterTemplate>
  26. </asp:Repeater>

cs代码:

  1. private DataSet dsMenus;//菜单
  2. protected void Page_Load(object sender, EventArgs e)
  3. {
  4. //绑定主菜单
  5. string connStr = "Data Source=ip地址;Initial Catalog=数据库名;User Id=sa;password=密码;";
  6. //SqlConnection conn = new SqlConnection(connStr);
  7. //conn.Open();
  8. string cmdText = "SELECT * FROM EP_menus WHERE status=1 ORDER BY orderid ASC,id ASC";
  9. //SqlCommand cmd = new SqlCommand(cmdText, conn);
  10. SqlDataAdapter adapter = new SqlDataAdapter(cmdText, connStr);
  11. dsMenus = new DataSet();
  12. adapter.Fill(dsMenus);
  13. DataView dvTopMenus = new DataView(dsMenus.Tables[0]);
  14. dvTopMenus.RowFilter = "[parent]=0";
  15. rptMenus.DataSource = dvTopMenus;
  16. rptMenus.DataBind();
  17. }
  18. protected void rptMenus_ItemDataBound(object sender, RepeaterItemEventArgs e)
  19. {
  20. if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
  21. {
  22. Repeater rptSMenus = (Repeater)e.Item.FindControl("rptSubMenus");
  23. DataRowView drv = (DataRowView)e.Item.DataItem;
  24. int pMenu = Convert.ToInt32(drv["id"]);//父级菜单id
  25. //if (pMenu != 0)
  26. //{
  27. DataView dvSubMenus = new DataView(dsMenus.Tables[0]);
  28. dvSubMenus.RowFilter = "[parent]=" + pMenu;
  29. if (dvSubMenus.Count > 0)
  30. {
  31. rptSMenus.DataSource = dvSubMenus;
  32. rptSMenus.DataBind();
  33. }
  34. //}
  35. }
  36. }

这里只是个大体的思路和代码,具体的Repeater等资料请参考其他的教程。

(转)asp.net(C#)手记之Repeater与两级菜单的更多相关文章

  1. ASP.NET(C#) Repeater分页的实现

    ASP.NET(C#) Repeater分页的实现 第一种方式: 数据库连接代码: using System; using System.Data; using System.Configuratio ...

  2. 在asp.net中使用confirm可以分为两种:

    在asp.net中使用confirm可以分为两种: 1.没有使用ajax,confirm会引起也面刷新 2.使用了ajax,不会刷新 A.没有使用ajax,可以用StringBuilder来完成. ( ...

  3. ASP.NET MVC 表单提交多层子级实体集合数据到控制器中

    于遇到了项目中实体类嵌套多层子级实体集合,并且子级实体集合的数据需要提交保存到数据库中的问题.针对此情况需要进行一些特殊的处理才可以将整个 实体类及子级实体集合数据提交表单到控制器中,解决的方法是根据 ...

  4. asp.net控件(1)Repeater

    1. 通过Repeater和数据源创建表格 <AlternatingItemTemplate>属性可以控制单元格交替显示不同的背景颜色 <table width=" sty ...

  5. 在Asp.Net MVC中使用Repeater控件

    使用Repeater控件在视图中展示图表信息,Repeater控件的使用概述: <asp:Repeater ID="Repeater1" runat="server ...

  6. ASP转PHP手记

    打算将动易网站管理系统移植到PHP环境中,寻寻觅觅了很多PHP内容管理网站,发现网上有动易转PHPCMS的代码,所以就拿定注意用PHPCMS的在google上找到一转换程序,动手做来还成功了,现将此次 ...

  7. 030. asp.net中DataList数据绑定跳转(两种方式)的完整示例

    前台代码: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.as ...

  8. ASP.NET MVC 开发中遇到的两个小问题

    最近在做一个网站,用asp.net MVC4.0来开发,今天遇到了两个小问题,通过查找相关渠道解决了,在这里把这两个问题写出来,问题非常简单,不喜勿喷,mark之希望可以给遇到相同问题的初学者一点帮助 ...

  9. 子级Repeater获取 父级Repeater

    第一种方法,子级Repeater中绑定父级的某个字段: <%# DataBinder.Eval((Container.NamingContainer.NamingContainer as Rep ...

随机推荐

  1. Eclipse自动生成文档注释

    /** *这种格式的注释就是文档注释 */ 快捷键是alt+shift+j,将光标放在类名,变量名,方法名上,按快捷键.

  2. C++重载操作符

    重载的函数操作符,对对象使用起来就像对象是一个函数一样 class A{public:A(int n);int operator()(int n);  //需要一个参数,返回int类型void out ...

  3. ionic初体验

    inoic使用入门安装inoic1.安装nodejs2.通过npm install -g iomic 在全局安装ionic3.通过ionic --help来查看帮助(其他命令详见弹出提示脚本) 后续收 ...

  4. 使用scrapy制作的小说爬虫

    使用scrapy制作的小说爬虫 爬虫配套的django网站  https://www.zybuluo.com/xuemy268/note/63660 首先是安装scrapy,在Windows下的安装比 ...

  5. string标准库的使用

    string s; s.empty() 如果 s 为空串,则返回 true,否则返回 false. s.size() 返回 s 中字符的个数 s[n] 返回 s 中位置为 n 的字符,位置从 开始计数 ...

  6. 转:Java反射教程

    原文来自于:http://www.importnew.com/9078.html 什么是反射?反射有什么用处? 1. 什么是反射? “反射(Reflection)能够让运行于JVM中的程序检测和修改运 ...

  7. Android 解决服务端验证码问题

    服务端验证码解决方法. 在服务端生成验证码后会把验证码字符串存在服务端的session中,等待用户提交进行比对.为了保证服务器与客户端的一对一的关系,所以出现了session 和cookie技术.客户 ...

  8. Visual Studio 2015 Owin+MVC+WebAPI+ODataV4+EntityFrawork+Identity+Oauth2.0+AngularJS 1.x 学习笔记之"坑"

    1.AngularJS route 与 MVC route http://www.cnblogs.com/usea/p/4211989.html public class SingleRoute : ...

  9. ural 1180 Stone Game

    http://acm.timus.ru/problem.aspx?space=1&num=1180 #include <cstdio> #include <cstring&g ...

  10. 【转】Java多线程操作局部变量与全局变量

    原文网址:http://blog.csdn.net/undoner/article/details/12849661 在这篇文章里,我们首先阐述什么是同步,不同步有什么问题,然后讨论可以采取哪些措施控 ...