.Net mvc总结
namespace WebMVCDemo.Controllers
{
/*
* 1.控制器名称为Home,控制器名称具有Controller后缀
*/
public class HomeController : Controller
{
// GET: Home
public ViewResult Index()
{
return View();
}
}
}
控制器中返回ViewResult对象,在调试时,出现以下错误:
该错误消息是很有帮助的。它不仅解释了MVC未找到该动作方法的视图,还显示出查找了哪些地方。这是MVC约定的另一个很好的例子:视图是通过命名约定与动作方法相关联的。这个动作方法称为”Index”,控制器称为”Home”,从上图可以看出,MVC试图在”Views”文件夹中查找具有这一名称的不同文件。
此时需要在view文件夹下创建相对应的文件进行视图渲染即可
使用布局页创建的视图
@{
ViewBag.Title = "First";
}
<h2>First</h2>
不使用布局页创建的视图
@{
Layout = null;
}
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width" />
<title>Index</title>
</head>
<body>
<div>
</div>
</body>
</html>
随后,VisualStudio将在Views\Home文件夹中创建一个名称为”Index.cshtml”的视图文件。这是MVC框架的另一个约定:视图被放置在Views文件夹中,文件夹的结构是与其关联的控制器名称相对应的。index.cshtml中的代码如下:
相比于正常的html文件格式,多了以下部分:
@{
Layout = null;
}
这个是由Razor视图引擎进行解释的表达式,Razor引擎处理视图内容并生成发送给浏览器的HTML。这是一个简单的Razor表达式,它告诉Razor未选用布局,布局类似于发送给浏览器的HTML模板。
在视图文件中添加以下代码:
@{
Layout = null;
}
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width" />
<title>Index</title>
</head>
<body>
<div>
<p>Hello c# mvc</p>
</div>
</body>
</html>
打开调试,出现下图即视图渲染成功
总结:在最初编辑Index动作方法时,它返回的是一个字符串值。这意味着MVC除了把这个字符串值传递给浏览器之外,未做其他事情。
现在Index方法返回了一个ViewResult对象,MVC框架渲染了一个视图并返回了它所产生的HTML,可是代码中并未告诉MVC应该使用哪一个视图,因此它会运用命名约定自动寻找一个视图。该约定是,视图具有动作方法的名称,并包含在以控制器命名的文件夹之中:Views/Home/Index.cshtml。