【MVC】VS常用技巧

1,在VS2010中,选中指定的代码段,可以拖拽到工具箱中,形成标签,以后还想书写类似的代码,双击鼠标即可。

2,在VS2012中,可以在注释上标注//TODO:我是注释

这样,注释就会出现在任务列表中,一些关键常用的方法/字段/关注点,通过这种方式快速定位。如图:

 

3,在VS2012中是不支持MVC1.0和MVC2.0的,如果要开启低版本MVC项目的话,必须使用VS2010

4,_ViewStart.cshtml文档会在所有其他所有视图(VIEW)运行之前载入。

发现使用布局页的视图没有完整的HTML结构,是因为类似的视图都作为一部分被装载到布局页中,由_ViewStart.cshtml文档指定,默认为_Layout.cshtml。

5,可以在视图页面的头部定义ViewBag的临时变量,而不必是在Controller的Action方法中定义,如图:

 

6,在浏览网页时,如果只是指定Controller,而不指定Action,而控制器和动作方法均是必须的路由参数,这时将去RegisterRoutes()方法中取默认的Action值,如图:

上图中默认的方法为Index,也就是说当我们输入.../example的时候,会自动路由为.../example/index

 

7,如果在View中定义了@model模型声明,那么通过Controller传进View的模型类型必须与View中所声明的类型兼容,否则将产生异常,如图:

 

8,在view文档(也就是cshtml中),<head>标签中的<title>标签指标题,如图:

 

9,如下代码:

<p>
@Html.ActionLink("Create New", "Create")
</p>

创建链接,因为没有指定链接的控制器名称,所以链接到当前控制器的Create动作方法,显示的文本为“Create New"。

 

10,HTTP GET POST

HTTP GET负责显示编辑的窗体,HTTP POST负责实际更新数据库里的属性。

 

11,杂:

@Html.HiddenFor(model => model.ID)   生成HTML窗体的隐藏域

HTML注释符号:<!--我是被注释的内容-->

在ASP.NET MVC中不建议使用Request对象和Response对象

不要在视图中撰写过多的程序逻辑,实现“关注点分离”

网址路由在MVC中的作用:

1、比对浏览器传过来的HTTP请求,对应到适当的控制器和Action进行处理;

2、决定MVC输出什么样的响应给浏览器;

 

12,网址路由

比如:单击“主页”链接,浏览器将URL封包,并发送HTTP要求到服务器上,IIS接收到这个HTTP封包,转给网址路由模块负责将HTTP请求交由那个HTTPHandler处理,对于MVC来说,自然是转交给MVCHandler处理,这才会进入MVC的运行声明周期。

  所有ASP.NET Web程序的入口点均是Application_Start()事件,其中 RouteConfig.RegisterRoutes(RouteTable.Routes);

  代码中的Routes是一个公开的静态变量,用来保存所有网址路由的规则集合,为RouteCollection类型的变量。

  routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

    代码中,表示不要通过网址路由处理,即如果从浏览器传递过来的网址,匹配该规则,将由IIS的其他Http模块处理,将不会进入ASP.MET MVC的生命周期。

  url: "{controller}/{action}/{id}"

  代码中URL样式包含三个路由参数,分别是Controller/Action/ID,注意该URL样式不能以‘/'开头。

  defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }

  默认值。当对比不到HTTP请求的网址时,会尝试带入代码中的默认值。

  当接收到HTTP请求时,将从上而下逐条比对,直到找到符合的网址格式。

  注意ID不算在网址路由之中,属于QueryString的部分。

1                 routes.MapRoute(
2                 name: "Default",
3                 url: "{controller}/{action}/{id}",
4                 defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
5             );        

  上述代码中,MapRoute使用的是具名参数。

13,MVC的运行声明周期

     网址路由比对-->运行Controller与Action-->运行View并回传结果

14,MVC在比对网址路由时,默认情况下,如果查找到网站实体目录中查找相应的实体文档,会自动略过所有网址路由比对。

   如果想打破这种默认行为,那么在MVC程序的入口Application_Start()中,添加如下代码:

  RouteTable.Routes.RouteExistingFiles = true;

  当网址路由比对成功时,MVC默认交由MvcHandler处理。

 

 


 

1,在ASP.NET MVC中,路由机制特别碉堡,直接对应于动作方法。没有必要给每一个动作方法添加视图,当视图返回View时,路由系统会自动寻找指定目录下的视图资源。

1 public ViewResult AutoProperty()
2 {
3        Product p = new Product();
4        p.Name = "Chris";
5        return View("Result", (object)String.Format("你是:{0}", p.Name));
6 }

如AutoProperty时HomeController中的动作方法,并没有指定视图,但是在返回视图的时候,会自动在Views\Home下查找指定的视图资源。

Url为~/Home/AutoProperty。同样验证了URL与动作方法的一致性。

 

2,@HTML

 @Html.DisplayNameFor(model => model.Email)显示属性名称,在定义属性时可以设置DisplayName属性来修改显示的名称。

如:

1         [DisplayName("电子邮件地址")]
2         public string Email { get; set; }

这样,@~处将不显示“Email”,而是显示“电子邮件地址”。

@Html.DisplayFor(modelItem => item.Name),显示的是特定Item的Name值,如:SharpL

 

@Html.ActionLink("Edit", "Edit", new { id=item.ID }) ,ActionLink用来输出超链接,第一个参数指超链接的显示文本,第二个参数指Action,第三个参数为路由参数。

 

@Html.LabelFor(model => model.Name),特定字段的显示名称,对于Email来说任然会显示“电子邮件地址”,所以和DisplayNameFor类似。

二者存在细微的差异,在输出的HTML中,LabelFor输出的内容包含<label>标签,而DisplayFor只会输出属性的显示名称。如图:

1         <div class="editor-label">
2             <label for="Email">电子邮件地址</label>
3         </div>

 

 

出处:

http://www.cnblogs.com/SharpL/p/4587010.html

http://www.cnblogs.com/SharpL/p/4549632.html

posted on 2018-05-24 15:47  jack_Meng  阅读(584)  评论(0编辑  收藏  举报

导航