.Net mvc总结

博客围绕MVC视图渲染展开,讲述控制器返回ViewResult对象调试时出现未找到视图的错误,指出可在view文件夹下创建对应文件解决。介绍了使用和不使用布局页创建视图的情况,还提及Razor视图引擎,最后总结MVC会按命名约定自动寻找视图。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值