带有RouteValueDictionary的ASP.NET核心路由

问题描述:

我需要创建标签助手来从多选择窗体生成URL。我记得,在旧的MVC我可以用这样的:带有RouteValueDictionary的ASP.NET核心路由

var i = 0; 
foreach (var attribute in PaginatorFilterItems) 
{      
    foreach (var attributeFilter in attribute.Value) 
    { 
     routeValues.Add($"{attribute.Key}[{i++}]", attributeFilter.ToString());   
    } 
    i=0; 
}  

现在,我可以在Url.Action使用它(...,...,routeValues)帮手,得到了这样的事情:

?str=val1&str=val2

但在dotnet核心我得到一些转义序列。我不知道为什么:

?str%5B0%5D=val1&str%5B1%5D=val2 

[]被转义并且不绑定到路由。我该如何解决它。我需要正确的收集格式:

?str=val1&str=val2&str=val3 ... 

谢谢你的时间。

编辑:

现在正在工作。但是对于这个例子,我没有使用RouteValueDictionary,而是使用了字符串列表和连接方法。

public class PaginatorPageTagHelper : TagHelper 
    { 
     public IDictionary<string, ICollection> PaginatorFilterItems { get; set; } 

     public string PaginatorController { get; set; } 
     public string PaginatorAction { get; set; } 
     public string PaginatorTitle { get; set; } 
     public int PaginatorPageNumber { get; set; } 
     public string PaginatorPageAttributeName { get; set; } 
     public string PaginatorAttributeCategory { get; set; } 

     public string PaginatorTagName { get; set; } 
     public IUrlHelper PaginatorUrlHelper { get; set; } 

     public override void Process(TagHelperContext context, TagHelperOutput output) 
     { 
      if(PaginatorUrlHelper == null) { 
       throw new NullReferenceException("UrlHelper parameter cannot be null."); 
      } 

      var attributeList = new List<string>();    
      var routeValues = new RouteValueDictionary(); 

      if (!string.IsNullOrEmpty(PaginatorAttributeCategory) && PaginatorFilterItems.ContainsKey(PaginatorAttributeCategory) && PaginatorFilterItems[PaginatorAttributeCategory].Count == 1) 
      { 
       routeValues.Add(PaginatorAttributeCategory, PaginatorFilterItems[PaginatorAttributeCategory].Cast<string>().First());          
      } 
      else 
      {     
       foreach (var attribute in PaginatorFilterItems) 
       {      
        foreach (var attributeFilter in attribute.Value) 
        { 
         attributeList.Add($"{attribute.Key}={attributeFilter.ToString()}"); 
        }      
       }    
      } 

      //can be <a> ,<link> or custom 
      output.TagName = PaginatorTagName ?? "a"; 
      output.Content.SetContent(PaginatorTitle);    
      routeValues.Add("page", string.Empty);    

      if (PaginatorPageNumber > 1) 
      { 
       routeValues["page"] = PaginatorPageNumber;     
      } 

      // create fallback for clasic filter, for example: /example?str=val1&str=val2 
      if (attributeList.Any()) 
      {     
       output.Attributes.SetAttribute("href", $"{this.GetPaginatorUrl(routeValues)}?{string.Join("&", attributeList)}"); 
       return; 
      }   

      output.Attributes.SetAttribute("href", this.GetPaginatorUrl(routeValues)); 
     } 

     private string GetPaginatorUrl(RouteValueDictionary routeValues) { 
      return PaginatorUrlHelper.Action(PaginatorAction, PaginatorController, routeValues); 
     } 
    } 
+0

也许这个问题是在标签助手的其余部分,因为在编译生成的html时避免编码该url/query字符串。你能分享你的标签帮手吗? –

+0

@ DanielJ.G。完成。 –

您可以使用标签的助手,如:

<a asp-area="" asp-controller="" asp-action="" asp-route-property1="value1" asp-route-property2="value2">my link</a>等。

+0

谢谢你的回答,但我有自定义标签助手,并且此代码位于其中。从视图中使用这是很好的。 –

我怀疑你的助手会返回一个MvcHtmlString,它将在视图中呈现时被编码。如果是这样,只需返回一个纯字符串。您需要确保手动对网址进行网址编码,但在渲染时不会进行编码。