码迷,mamicode.com
首页 > Web开发 > 详细

MVC笔记--特性路由

时间:2017-07-01 01:03:23      阅读:313      评论:0      收藏:0      [点我收藏+]

标签:pre   sid   desc   视图   图片   复杂   ace   data   参数   

  • 物性路由:将路由和控制器放在一起,这样更简单方便,还可以处理复杂的路由场景
  • 传统路由:集中、强制、基于代码风格来定义的。
每个MVC应用程序都需要路由来定义自己的处理请求方式,路由是MVC是应用程序的入口点。我们先了解一下路由涉及的主要概念:路由定义是从URL模板开始的,因为它指定了与路由相匹配的模式。路由定义可以做为控制器类或操作方法的特性。路由可以指定的它的URL及其默认值,此外,它还可以约束URL的各个部分,提供关于路由如何及何时与传入的URL相匹配的严格控制。
创建一个MVC程序后,我们可以在Application_Start/RouteConfig.cs文件中。因为我们这次主要讲特性路由,所以可以先删除里面默认的所有内容,通过MapMvcAttributeRout()方法来定义。
在HomeController中随便找一个视图前面加上[route("")],我这里用的是about,定义的路由名为”aboutTest“
 
[Route("aboutTest")]
public ActionResult About()
{
ViewBag.Message = "Your application description page.";
 
return View();
}
URL用这个访问:http://localhost:8957/ceshi
技术分享
*这些URL就不要写home/ceshi了,因为我们已经定义路由,直接输入就可以访问
 技术分享
控制器路由:前面看了如何把路由特性直接添加到操作方法上,但很多时侯控制器类中的方法遵循的模式具有相似的路由特情,这里我们可以定一下action的特殊路由参数,以后该控制器下的路由就不用重复写相似的代码了
/// <summary>
/// 定义路由映射
/// </summary>
[Route("{home}/{action}")]
public class HomeController : Controller
{
public ActionResult About()
{
ViewBag.Message = "Your application description page.";
 
return View();
}
}
当然用这种方式后,控制器上也可以添加特性路由,也是可以访问的
我们也可以使用前缀“RoutePrefix”
/// <summary>
/// 定义路由映射--使用前缀
/// </summary>
[RoutePrefix("home")]
[Route("{action}")]
这样程序会帮我们自动加上“home”控制器的前缀,两者皆支持覆盖行为,即为一个控制器指定多个路由规则:
[Route("")]
[Route("default")]
public ActionResult Index()
{
return View();
}
这两条URL都可以访问到同一个控制器
* [Route("{home}/{action}")]:用这种方式,控制器前台有指定路由,URL访问不用输入控制器的前缀例:
这两条URL访问的都是Index控制器。如果没有为控制器添加特性路由,在访问时就要添加控制器的名字(前缀)
例:http://localhost:8957/home/About 这条URL访问的是“About”控制器
public ActionResult About()
{
ViewBag.Message = "Your application description page.";
 
return View();
}
路由约束:当我们使用带有参数的路由时,会发现如果我们想让相同的路由,不同的参数分别访问不同的控制器时,我们就要用到路由约束
[Route("ceshi/{id:double}")]
public ActionResult Test1(string id)
{
return View();
}
技术分享
技术分享
下面的图片是内联表,我偷个懒,切了一张图片;
技术分享
 技术分享
(未完,待续)

MVC笔记--特性路由

标签:pre   sid   desc   视图   图片   复杂   ace   data   参数   

原文地址:http://www.cnblogs.com/c546170667/p/7101084.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!