使用CSS+SiteMap+UserControl+MasterPage实现简易的Tab

我们在做网站后台管理的时候,往往需要用到Tab形式的导航菜单,博客园如此,BlogEngine也如此,前段时间研究修改BlogEngine的时候看到其Tab实现如此容易,思路不错,但是有一点使我郁闷,他的Tab标题是取文件名,而使用中文的文件名是写程序的大忌,自然就想到了Asp.Net2.0的特性Web.sitemap,我们的数据源如何不从它来,于是简单写了下,其实很简单,只需要一个样式文件,一个SiteMap,一个通用的UserControl,一个母版页。

 

下面是核心Code)

protected void Page_Load(object sender, EventArgs e)
        {
            
if (!Page.IsCallback)
            {
                BindMenu();
            }
        }
    

        
/// <summary>
        
/// Binds the menu.
        
/// </summary>
        private void BindMenu()
        {
            SiteMapNodeCollection smnc 
= SiteMap.CurrentNode.ParentNode.ChildNodes;

            
foreach (SiteMapNode smn in smnc)
            {
                AddItem(smn.Title, smn.Url);
            }
        }

        
/// <summary>
        
/// Adds the item.
        
/// </summary>
        
/// <param name="text">The text.</param>
        
/// <param name="url">The URL.</param>
        public void AddItem(string text, string url)
        {
            HtmlAnchor a 
= new HtmlAnchor();
            a.InnerHtml 
= "<span>" + text + "</span>";
            a.HRef 
= url;

            
if (Request.RawUrl.EndsWith(url, StringComparison.OrdinalIgnoreCase))
                a.Attributes[
"class"= "current";

            HtmlGenericControl li 
= new HtmlGenericControl("li");
            li.Controls.Add(a);
            ulMenu.Controls.Add(li);
        }

运行效果:

image

源码下载:web projectTab.zip
          web site Tab.rar

posted @   冰戈  阅读(3701)  评论(18编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示