溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

在MVC下怎么用XML實(shí)現(xiàn)breadcrumbs導(dǎo)航欄

發(fā)布時(shí)間:2021-11-03 18:00:46 來(lái)源:億速云 閱讀:115 作者:小新 欄目:編程語(yǔ)言

小編給大家分享一下在MVC下怎么用XML實(shí)現(xiàn)breadcrumbs導(dǎo)航欄,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

先看下樣子在MVC下怎么用XML實(shí)現(xiàn)breadcrumbs導(dǎo)航欄

像這種導(dǎo)航欄(breadcrumbs)在mvc下我們來(lái)實(shí)現(xiàn)他。我們采用XML來(lái)實(shí)現(xiàn)這個(gè)功能。

1.首先做個(gè)準(zhǔn)備,我們編寫(xiě)rounting規(guī)則(順便提一句,我們要用到rounting功能,所以規(guī)則必須寫(xiě)正確,不然出不來(lái)喔)

代碼如下

public static void RegisterRoutes(RouteCollection routes)          {              routes.IgnoreRoute("{resource}.axd/{*pathInfo}");              routes.MapRoute(               "inner",                                              // Route name               "resume/test/inner/{action}/{id}",                           // URL with parameters               new { controller = "inner", action = "Index", id = "" }  // Parameter defaults               );              routes.MapRoute(             "test",                                              // Route name             "resume/test/{action}/{id}",                           // URL with parameters             new { controller = "test", action = "Index", id = "" }  // Parameter defaults             );              routes.MapRoute(                  "Default",                                              // Route name                  "{controller}/{action}/{id}",                           // URL with parameters                  new { controller = "Home", action = "Index", id = "" },                  new { controller = "^(?!(test|inner)).*$", action = "^(?!test).*$" }              );            }

我們加了兩個(gè)規(guī)則

/resume/test

和/resume/test/inner

2.編寫(xiě)用到的XML文件,注意是樹(shù)形結(jié)構(gòu)的

在models寫(xiě)個(gè)Navigator.xml

<?<?xml version="1.0" encoding="utf-8" ?> <node Title="首頁(yè)"  Description="潘峰的網(wǎng)站" Action="Index" Controller="Home">   <node Title="簡(jiǎn)歷" Description="在線簡(jiǎn)歷" Action="Index" Controller="Resume">     <node Title="Test" Description="Test" Action="Index" Controller="test">       <node Title="inner" Description="inner" Action="Index" Controller="inner">       </node>     </node>   </node> </node>

3.編寫(xiě)我們的類(lèi)文件來(lái)實(shí)現(xiàn)Navigator

在models寫(xiě)個(gè)navigatorHelper.cs

using System;  using System.Collections.Generic;  using System.Linq;  using System.Web;  using System.Xml;  using System.Xml.Linq;  using System.Web.Routing;  using System.Web.Mvc;  using System.IO;  using System.Text;   namespace conansoft.Helpers  {      public static class MenuHelper      {          private static HttpServerUtilityBase Server = null;
  •         private static HttpRequestBase Request = null;  

  •         private static UrlHelper Url = null;  

  •         private static RouteValueDictionary RouteDictionary = null;  

  •         public static string Navigator(this HtmlHelper helper)  

  •         {  

  •             Server = helper.ViewContext.RequestContext.HttpContext.Server;  

  •             Request = helper.ViewContext.RequestContext.HttpContext.Request;  

  •             Url = new UrlHelper(helper.ViewContext.RequestContext);  

  •             RouteDictionary = helper.ViewContext.RequestContext.RouteData.Values;  

  •             string xmlPath = Server.MapPath(Url.Content("~/Models/Navigator.xml"));  

  •             XDocument doc = XDocument.Load(xmlPath);  

  •             XElement node = FindNode(doc.Root);  

  •             StringBuilder sb = new StringBuilder();  

  •             Stack s = new Stack();  

  •             while (node != null)  

  •             {  

  •                 s.Push(node);  

  •                 nodenode = node.Parent;  

  •             }  

  •             //輸出breadcrumbs.可以自行修改使之符合你的要求  

  •             while (s.Count() != 0)  

  •             {  

  •                 node = s.Pop();  

  •                 if (UrlEqual(node))  

  •                 {  

  •                     sb.AppendLine(string.Format("{0}", node.Attribute("Title").Value, node.Attribute("Description").Value));  

  •                 }  

  •                 else  

  •                 {  

  •                     sb.AppendLine(string.Format("{0}", node.Attribute("Title").Value,  

  •                         Url.Action(node.Attribute("Action").Value, node.Attribute("Controller").Value),  

  •                         node.Attribute("Description").Value));  

  •                     sb.AppendLine(" > ");  

  •                 }  

  •             }  

  •             return sb.ToString();  

  •         }  

  •  

  •         ///   

  •         /// 查找當(dāng)前節(jié)點(diǎn)  

  •         ///   

  •         /// 當(dāng)前節(jié)點(diǎn)  

  •         /// 找到返回,找不到為空  

  •         private static XElement FindNode(XElement e)  

  •         {  

  •             XElement result = e;  

  •               

  •             

  •             if (UrlEqual(e))  

  •             {  

  •                 return e;  

  •             }  

  •             else  

  •             {  

  •                 if (e.HasElements)  

  •                 {  

  •                     foreach (XElement ee in e.Elements())  

  •                     {  

  •                         result = FindNode(ee);  

  •                     }  

  •                 }  

  •                 else  

  •                 {  

  •                     return null;  

  •                 }  

  •                 return result;  

  •             }  

  •         }  

  •  

  •         ///   

  •         /// Url是否相等  

  •         ///   

  •         /// 節(jié)點(diǎn)  

  •         private static bool UrlEqual(XElement e)  

  •         {  

  •             string url1 = Url.Action(e.Attribute("Action").Value, e.Attribute("Controller").Value).ToLower();  

  •             string url2 = Url.RouteUrl(RouteDictionary).ToLower();  

  •             return url1 == url2;  

  •         }  

  •     }  

  • 解釋一下我們利用xml文件來(lái)實(shí)現(xiàn)breadcrumbs,并且我們用action和controller來(lái)判斷是否為當(dāng)前路徑[UrlEqual]

    在網(wǎng)頁(yè)中加入

    <%=Html.Navigator() %>  <%=Html.Navigator() %>

    好了效果如下在MVC下怎么用XML實(shí)現(xiàn)breadcrumbs導(dǎo)航欄

    看完了這篇文章,相信你對(duì)“在MVC下怎么用XML實(shí)現(xiàn)breadcrumbs導(dǎo)航欄”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

    向AI問(wèn)一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI