MVC3中_ViewStart.cshtml的一些事

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。

26B9E5B4F3D84758B37911B1AEBFA8B9

如果方法改为如下:

public ActionResult ViewUserControl1()

{

return PartialView();

}

 

则_Viewstart.cshtml中的代码不会被执行,因此写的Layout = “~/Views/Shared/_Layout.cshtml”;之类的代码也不会被执行,返回的就是单纯的一个Partial View。

D1BD171968FA4A2A8C5C4860E29C3CF5

如果在View的Home目录下也有一个同名的_ViewStart.cshtml文件,那么这个_ViewStart也会被调用,但是会最先调用的还是最外面的_ViewStart,然后再是Home目录下的_ViewStart。

0I]EI239P@XU)J]Y74BNL~3

例如:Home目录下的_ViewStart.cshtml文件内容为:

@{

@Html.Raw(“<b>_ViewStart.cshtml in home</b>”);

}

 

则当呈现ViewUserControl1得到的结果如下:

F0309D6D2F3242FDA1C66A245D16FBC6

至于_ViewStart.cshtml为何前面要加’_’符号,可以参考文章http://cnn237111.blog.51cto.com/2359144/814704