.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。

猜你喜欢

转载自blog.csdn.net/weixin_40550118/article/details/110530876