.NET8入门:13.ASP.NET Core MVC

ASP.NET Core MVC是一种十分经典的软件设计模式架构,接下来我们来了解一下MVC在ASP.NET8中的一些基础概念。

MVC架构

MVC架构主要包含以下三层:

M(Model):模型层,其职责为UI显示以及业务逻辑或操作所需要的实体对象模型,一般与数据库表存在映射关系。

V(View):视图层,其职责为人机交互页面,展示以及操作数据。

C(Controller):控制器层,其职责为处理数据交互以及业务逻辑,为数据与UI进行交互的一层。

MVC架构引用关系如下:

创建MVC项目

详情查看第二章使用模板创建.NET Core Web

控制器

在MVC中控制器是用来处理用户输入和交互并进行响应的。

添加控制器

选中Controllers文件夹------>右键------>添加------>控制器

选择空控制器

输入控制器名称后点击添加

添加成功后的控制器代码

为控制器添加视图

选中Index方法------>右键------>添加视图

添加Razor视图-空

Views/Test目录下生成了刚才Index方法的视图

生成规则:Vilews/控制器名称/方法名

视图

在Index.cshtml页面中添加以下代码:

cs 复制代码
@{
    ViewData["Title"] = "Test Page";
}

<div class="text-center">
    <h1 class="display-4">Hello World</h1>
</div>

启动应用并在URL后添加/Test(控制器名称),会命中TestController控制器下的Index方法所绑定的视图。展示效果如下图:

在布局页面(Views/Shared/_Layout.cshtml)添加刚才新加的视图的入口

在asp.net core mvc中a标签内插入asp-area="" asp-controller="Test" asp-action="Index"表示跳转到Test控制器的Index方法

html 复制代码
                        <li class="nav-item">
                            <a class="nav-link text-dark" asp-area="" asp-controller="Test" asp-action="Index">Test</a>
                        </li>

将上面代码插入到标红的代码处

点击Test进入到Test控制器的Index页面

模型

选中Models文件夹------>右键------>添加------>类

输入类名------>点击添加

在新建的类中输入以下代码

cs 复制代码
    public class TestModel
    {
        public int Id { get; set; }

        public string Message { get; set; }
    }

修改Test控制器代码创建一个model实例并返回给视图

cs 复制代码
    public class TestController : Controller
    {
        public IActionResult Index()
        {
            TestModel model = new TestModel()
            {
                Id = 1,
                Message = "Hello,Test Message"
            };
            return View(model);
        }
    }

修改Test\Index.cshtml代码,通过@model指令指定视图对象类型,并通过@HTML辅助标签来访问控制器中返回给视图的model实例

cs 复制代码
@model TestModel

@{
    ViewData["Title"] = "Test Page";
}

<div class="text-center">
    <h1 class="display-4">Hello World</h1>
    <h1 class="display-4">ID:@Html.DisplayFor(model=>model.Id)</h1>
    <h1 class="display-4">Message:@Html.DisplayFor(model => model.Message)</h1>
</div>

访问结果如图

相关推荐
lzhdim29 分钟前
一款基于 .Net WinForm 开发的节点编辑器,纯 GDI 实现,体积仅 100+Kb
编辑器·.net
代码不停1 小时前
Spring Web MVC
前端·spring·mvc
步步为营DotNet1 小时前
.NET 11 中.NET Aspire 在云原生应用多环境部署与安全治理的深度实践
安全·云原生·.net
无风听海10 小时前
深入剖析 YARP 的 Transforms:构建灵活的反向代理转换管道
后端·中间件·asp.net
我是唐青枫10 小时前
终于不用手搓两级缓存了!C#.NET HybridCache 详解:L1 L2、标签失效与防击穿实战
redis·缓存·c#·.net
TeamDev17 小时前
在 Excel 加载项中嵌入 Web 视图
前端·后端·.net
追逐时光者18 小时前
C#/.NET/.NET Core技术前沿周刊 | 第 70 期(2026年5.01-5.10)
后端·.net
极创信息19 小时前
信创软件快速适配信创改造,实战落地思路
java·大数据·数据库·人工智能·mvc·软件工程·hibernate
nnsix1 天前
Unity API 兼容的 .NET Standard 2.1 和 .NET Framework 区别
unity·游戏引擎·.net
码农刚子1 天前
.NET 8 Web开发入门(三):解构引擎——依赖注入(DI)与中间件管道
.net