首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >自定义SiteMapPath,如Bootstrap Breadcrumb

自定义SiteMapPath,如Bootstrap Breadcrumb
EN

Stack Overflow用户
提问于 2018-11-12 11:16:30
回答 1查看 360关注 0票数 0

在Asp.Net网站中,我们可以使用SiteMap和SiteMapPath简单地添加面包屑。但是SiteMapPath在网站上添加了一个非常简单的面包屑。

我希望自定义我的网站上的SiteMapPath,以包含来自FontAwesome的图标,用于SiteMapPath中的每个节点。另外,我想设计我的SiteMapPath,类似于我在下面添加的片段。

代码语言:javascript
复制
.breadcrumb-SiteMaster {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 12px;
}

.breadcrumbSM {
    list-style: none;
    display: inline-block;
}

.breadcrumbSM .icon {
    font-size: 14px;
}

.breadcrumbSM li {
    float: left;
}

.breadcrumbSM li a {
    color: #FFF;
    display: block;
    background: #3498db;
    text-decoration: none;
    position: relative;
    height: 40px;
    line-height: 40px;
    padding: 0 10px 0 5px;
    text-align: center;
    margin-right: 23px;
}

.breadcrumbSM li:nth-child(even) a {
    background-color: #2980b9;
}

.breadcrumbSM li:nth-child(even) a:before {
    border-color: #2980b9;
    border-left-color: transparent;
}

.breadcrumbSM li:nth-child(even) a:after {
    border-left-color: #2980b9;
}

.breadcrumbSM li:first-child a {
    padding-left: 15px;
    -moz-border-radius: 4px 0 0 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px 0 0 4px;
}

.breadcrumbSM li:first-child a:before {
    border: none;
}

.breadcrumbSM li:last-child a {
    padding-right: 15px;
    -moz-border-radius: 0 4px 4px 0;
    -webkit-border-radius: 0;
    border-radius: 0 4px 4px 0;
}

.breadcrumbSM li:last-child a:after {
    border: none;
}

.breadcrumbSM li a:before, .breadcrumbSM li a:after {
    content: "";
    position: absolute;
    top: 0;
    border: 0 solid #3498db;
    border-width: 20px 10px;
    width: 0;
    height: 0;
}

.breadcrumbSM li a:before {
    left: -20px;
    border-left-color: transparent;
}

.breadcrumbSM li a:after {
    left: 100%;
    border-color: transparent;
    border-left-color: #3498db;
}

.breadcrumbSM li a:hover {
    background-color: #1abc9c;
}

.breadcrumbSM li a:hover:before {
    border-color: #1abc9c;
    border-left-color: transparent;
}

.breadcrumbSM li a:hover:after {
    border-left-color: #1abc9c;
}

.breadcrumbSM li a:active {
    background-color: #16a085;
}

.breadcrumbSM li a:active:before {
    border-color: #16a085;
    border-left-color: transparent;
}

.breadcrumbSM li a:active:after {
    border-left-color: #16a085;
}
代码语言:javascript
复制
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.css">
<div class="breadcrumb-SiteMaster">
  <ul class="breadcrumbSM">
    <li><a href="#"><span><i class="fa fa-home"></i></span></a></li>
    <li><a href="#"><span><i class="fa fa-file"></i></span> Projects</a></li>
    <li><a href="#"><span><i class="fa fa-angle-double-right"></i></span> Breadcrumb</a></li>
    <li><a href="#"><span><i class="fa fa-rocket"></i></span> Getting started</a></li>
    <li><a href="#"><span><i class="fa fa-arrow-down"></i></span> Download</a></li>
  </ul>
</div>

我试着在SiteMapPath中使用CSS,但没有起作用。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-11-13 19:11:53

找到了问题的答案。在谷歌上做了一些搜索,发现通过使用ControlAdapter和BrowserFile,我可以编辑SiteMapPath,使其类似于Breadcrumb。

首先,您需要添加一个名为SiteMapPathControlAdapter的类,它将继承WebControlAdapter,然后在其中编辑SiteMapPath的布局。

代码语言:javascript
复制
public class SiteMapPathControlAdapter : WebControlAdapter
{
    public virtual string LinkCssClass
    { get; set; }
    protected override void RenderBeginTag(HtmlTextWriter writer)
    {
        writer.WriteLine();
        writer.WriteBeginTag("div");
        writer.WriteAttribute("class", ((System.Web.UI.WebControls.SiteMapPath)(Control)).CssClass);
        writer.Write(HtmlTextWriter.TagRightChar);
        writer.WriteBeginTag("ul");
        writer.WriteAttribute("class", "breadcrumbSM");
        writer.Write(HtmlTextWriter.TagRightChar);
    }
    protected override void RenderEndTag(HtmlTextWriter writer)
    {
        writer.WriteEndTag("ul");
        writer.WriteEndTag("div");
        writer.WriteLine();
    }
    protected override void RenderContents(HtmlTextWriter writer)
    {
        writer.Indent++;
        SiteMapPath item = (SiteMapPath)Control;
        SiteMapProvider Provider = ((System.Web.UI.WebControls.SiteMapPath)(Control)).Provider;
        SiteMapNodeCollection collection = new SiteMapNodeCollection();
        SiteMapNode node = Provider.CurrentNode;
        if (node != null)
        {

            collection.Add(node);
            while (node != Provider.CurrentNode.RootNode)
            {
                node = node.ParentNode;
                collection.Add(node);
            }

        }
        BuildItems(collection, true, writer);
        writer.Indent--;
        writer.WriteLine();
    }
    private void BuildItems(SiteMapNodeCollection items, bool isRoot, HtmlTextWriter writer)
    {
        if (items.Count > 0)
        {
            writer.WriteLine();

            writer.Indent++;
            for (int i = items.Count - 1; i > -1; i--)
            {
                BuildItem(items[i], writer);
            }
            writer.Indent--;
            writer.WriteLine();
        }
    }
    private void BuildItem(SiteMapNode item, HtmlTextWriter writer)
    {
        if ((item != null) && (writer != null))
        {
            if (item.Url.Length > 0)
            {
                writer.WriteLine();
                writer.WriteBeginTag("li");
                writer.Write(HtmlTextWriter.TagRightChar);

                writer.WriteBeginTag("a");
                writer.WriteAttribute("href", Page.ResolveUrl(item.Url));
                writer.Write(HtmlTextWriter.TagRightChar);

                writer.WriteBeginTag("span");
                writer.Write(HtmlTextWriter.TagRightChar);

                writer.WriteBeginTag("i");
                writer.WriteAttribute("class", string.Format("fa fa-{0}", item.Description));
                writer.Write(HtmlTextWriter.TagRightChar);
                writer.WriteEndTag("i");

                writer.WriteEndTag("span");

                if (item.Title == "Home")
                {
                    writer.Write("");
                }
                else
                {
                    writer.Write(string.Format(" {0}", item.Title));

                    writer.WriteEndTag("a");

                    writer.WriteEndTag("li");

                    writer.WriteLine();
                }
            }
        }
    }
}

}

在此之后,将一个 BrowserFile 添加到您的项目中,并通过在BrowserFile中添加以下行将其链接到最近在项目中添加的ControlAdapter类。

代码语言:javascript
复制
<browser refID="Default">
    <controlAdapters>
       <adapter controlType="System.Web.UI.WebControls.SiteMapPath" adapterType="SiteMapPathControlAdapter" />
    </controlAdapters>
</browser>

然后,您所需要做的就是将SiteMapPath添加到Site.Master中,以便在所有页面上都可用,并将CssClass设置为Site.Master,这样就可以了。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53261019

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档