标签:
简单了了解了下MVC的基本开发步骤后,又对MVC的语法和模版详细看看了,小小总结下
对mvc开发,首先是要对布局有个基本的认识。Razor引擎使页面元素更加清晰
简单认识下
如
1
2
3
4
|
<linkhref= "@url.content(" ~ content= "" site.css ")" rel= "stylesheet" type= "text/css" > <scriptsrc= "@Url.Content(" ~/Scripts/jquery- 1.7 . 1 .min.js ")" type= "text/javascript" ></script> <scriptsrc= "@Url.Content(" ~/Scripts/jquery- 1.7 .js ")" type= "text/javascript" ></script> <scriptsrc= "@Url.Content(" ../../Scripts/Highcharts- 3.0 . 1 /js/highcharts.js ")" type= "text/javascript" ></script></linkhref= "@url.content(" ~> |
到了页面会自动找到相应的js
在模板页中我们会定义一些全局性的CSS,JS等文件,而与具体页面相关的CSS和JS文件及代码,我们可以保留在@RenderSection("Head", false)中,它能够让页面通过@section Head{}的形式,将个性化的代码呈现,其中参数false表示,具体页面可以不去实现这个section Head块。
模版页面定义
1
2
3
|
<div class = "page" > @RenderSection ( "Head" , false ); <!-- 页面中可以没有Head节点--> </div><span style= "font-family: SimSun;font-size:18px; " class = "" > </span> |
添加一个About.cshtml,
然后就可以在About.cshtml中定义"Head"要呈现的内容
1
2
3
4
5
|
@section Head{ <script> alert( "Hello MVC3" ); </script> } |
可以是系统插件化 就是可以分离的东西绝对不要让他们在一起,因为只有每个功能模块都是单独的,我们才可以在其他位置重用它 分工合作现在是一个合作的时代,没有任何一个人可以单独完成规定的任务而不与别人合作,除非是牛人例外。分部视图可以带给我们开发不同模块中的分工合作。
Html.partial和RenderPartial都是输出html片段,区别在于Partial是将视图内容直接生成一个字符串并返回(相当于有个转义的过程),RenderPartial方法是直接输出至当前 HttpContext(因为是直接输出,所以性能好)。因此它们在视图中的使用方式是不同的
@Html.Partial,@Html.Action,@Html.RenderPartial,@Html.RenderAction,@Html.ActionLink
以上各个方法都是调用然后返回信息
不同点
1、带有Render的方法返回值是void,在方法内部进行输出;不带的返回值类型为MvcHtmlString,所以只能这样使用:
1
2
|
@Html .Partial对应 @{Html.RenderPartial(....);} @Html .Action对应 @{Html.RenderAction(....);} |
2、Html.Partial可以直接提供用户控件名作为参数,
而Html.Action需要有对应的Action,在Action内部返回PartailResult(即retunPartialView())。
3、对于简单的没有任何逻辑的用户控件,推荐使用Html.Partial;对于需要设置一些Model的用户控件,推荐使用Html.Action。当然,有Model数据也是可以使用Html.Partial方法的,可以看方法的重载。
control是一个抽象类,该类封装了不少的方法,返回类型很多是引用类型。所以我们在书写返回值的时候尽可能的去查看父类的方法
如:发现父类的虚方法,那么我们就可以通过control返回以下这些类型。
FileContentResultfile()ContentResultcontent()JesonResultjson()PartialViewResultpartialView()ReirectToresultResultRediretToaction()
MVC3以后的书写和语法大大简化的开发难度,同时在加入的一些分布视图上,起到了很好的开发效果。学习的难度并没有增大。本小结是对学习中简单的认识,还请多多指教。
标签:
原文地址:http://www.cnblogs.com/ranran/p/4191931.html