MVC3中,使用Razor模板引擎的话,会自动生成一个_ViewStart.cshtml文件。
很多人把这个文件当成类似Webform中的Master模板文件,其实这个_ViewStart.cshtml文件和模板文件没有任何关系,要说有关系,也仅仅是默认生成的时候,里面有一个语句
Layout = "~/Views/Shared/_Layout.cshtml";
其实这句话才是和模板有点关系的。
事实上,_Viewstart.cshtml的作用是在呈现View文件的时候的启动文件,无论哪个视图,当你要呈现这个视图的之前,_Viewstart.cshtml中的代码总会被先执行,正如把它的名字命名为_Viewstart哪样,这是Razor引擎故意设计的,因此如果项目中所有的视图都要包含某些公共逻辑,比如设置Layout = "~/Views/Shared/_Layout.cshtml";这样的语句,只需在_Viewstart.cshtml写一遍就可以了。
注意,是在View被呈现的时候才会调用_Viewstart.cshtml,如果一个View是按照PartialView的方式输出的,则不会触发_Viewstart.cshtml中的代码。
举个例子。
假设在_Viewstart.cshtml中有如下代码:
- @{
- Layout = "~/Views/Shared/_Layout.cshtml";
- @Html.Raw("Hello")
- }
- <div>World</div>
--------------------------------------
访问Home/ViewUserControl1调用的Action方法如下:
- public ActionResult ViewUserControl1()
- {
- return View();
- }
此方法返回ViewUserControl1视图。注意:当View方法参数为空的时候,默认是使用当前的action名字,即会去找ViewUserControl1.cshtml的View。
如果方法改为如下:
- public ActionResult ViewUserControl1()
- {
- return PartialView();
- }
则_Viewstart.cshtml中的代码不会被执行,因此写的Layout = "~/Views/Shared/_Layout.cshtml";之类的代码也不会被执行,返回的就是单纯的一个Partial View。
如果在View的Home目录下也有一个同名的_ViewStart.cshtml文件,那么这个_ViewStart也会被调用,但是会最先调用的还是最外面的_ViewStart,然后再是Home目录下的_ViewStart。
例如:Home目录下的_ViewStart.cshtml文件内容为:
- @{
- @Html.Raw("<b>_ViewStart.cshtml in home</b>");
- }
则当呈现ViewUserControl1得到的结果如下:
至于_ViewStart.cshtml为何前面要加'_'符号,可以参考文章http://cnn237111.blog.51cto.com/2359144/81470