我有一系列看起来像

的网址
/Catalog/Ajax/Update/{ViewToUpdate}?var1=a&var2=b&var3=c

目前我已经设置了几个路由 - 每个路由一个{ViewToUpdate},我想要做的是将{ViewToUpdate}传递给我的Action处理程序,这样我就可以压缩我的代码。而不是:

public ActionResult AjaxUpdateNavigation(string var1, string var2, string var3) {}

我想:

public ActionResult AjaxUpdateNavigation(string ViewToUpdate, string var1, string var2, string var3) {}

以下是我目前的路线:

routes.MapRoute(
"CatalogAjaxNavigation",
"Catalog/Ajax/Update/Navigation",
new { controller = "Catalog", action = "AjaxUpdateNavigation" }
);

如何正确设置路由定义以处理{ViewToUpdate}字符串以及仍传入查询字符串?

TIA

有帮助吗?

解决方案

这是我的路线:

  routes.MapRoute("TestThing", "test/{ViewToUpdate}", new {controller = "Home", action = "TestQSParams"});

这是我的行动:

  public ActionResult TestQSParams(string ViewToUpdate, string var1, string var2)
  {
      TestQSParamsModel m = new TestQSParamsModel {var1 = var1, var2 = var2, ViewToUpdate = ViewToUpdate};
      return View("TestQSParams", m);
  }

这是我的模特:

public class TestQSParamsModel
  {
      public string ViewToUpdate { get; set; }
      public string var1 { get; set; }
      public string var2 { get; set; }
  }

以下是我的观点:

From QS:<br />
  <% foreach(string s in Request.QueryString) 
         Response.Write(string.Format("{0}={1}<br />", s, Request.QueryString[s])); %>
  <br />
  <br />
  From Model:<br />
  <asp:Literal ID="modelvars" runat="server"></asp:Literal>

视图代码隐藏:

  protected void Page_Load(object sender, EventArgs e)
  {
      modelvars.Text = string.Format("{0}<br />{1}<br />{2}", Model.var1, Model.var2, Model.ViewToUpdate);
  }

我的网址:

/test/ThisView?var0=douglas&var1=patrick&var2=caldwell

最后,我的结果:

  From QS:   
  var0=douglas   
  var1=patrick   
  var2=caldwell

  From Model:
  patrick
  caldwell
  ThisView

其他提示

routes.MapRoute(
"CatalogAjaxNavigation",
"Catalog/Ajax/Update/{ViewToUpdate}",
new { controller = "Catalog", action = "AjaxUpdateNavigation" , ViewToUpdate = (string)null }
);


public ActionResult AjaxUpdateNavigation(string ViewToUpdate, string var1, string var2, string var3) {}
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top