asp.net core mvc之 视图

一、在控制器中找到匹配视图,然后渲染成 HTML 代码返回给用户

cs 复制代码
public class HomeController : Controller
{
     public IActionResult Index()
     {
         return View(); //默认找 Views/Home/Index.cshtml ,呈现给用户
     }
}

二、指定视图

1、控制器

cs 复制代码
public class HomeController : Controller
{
     public IActionResult Index()
     {
         return View("~/Views/Home/abc.cshtml");
     }
}

视图有它自己的语法,这个语法就是 Razor语法

2、abc.cshtml 视图

cs 复制代码
@{
    string str = "字符串";
}

<h1>abc</h1>
<h3>@str</h3>

三、控制器给视图传递数据(强类型)

1、UserController 控制器 中 DoRegister 方法

cs 复制代码
public class UserController : Controller
{

     public IActionResult DoRegister(UserInfo userInfo)
     {
          if (ModelState.IsValid)
          {
              return View("~/Views/User/Detail.cshtml",userInfo);
          }         
     }
}

2、创建 Detail.cshtml 视图

cs 复制代码
@model FirstCoreMvc.Models.UserInfo

<h1>@Model.Name</h1>

四、控制器给视图传递数据(弱类型)

1、ViewData["键"]

HomeController.cs 控制器
cs 复制代码
public class HomeController : Controller
{
        public IActionResult Index()
        {
            var currentUser = new UserInfo() { Name="xiaoxiao",Password="1234"};
            ViewData["currentuser"] = currentUser;
            return View(); //默认找 Views/Home/Index.cshtml ,呈现给用户
        }
}
视图使用
cs 复制代码
@{
    var currentUser = ViewData["currentuser"] as UserInfo;
}
<h1>@currentUser.Name</h1>

也可以在视图( Views/Home/Index.cshtml )中定义 @{ ViewData["Title"] = "Home Page"; } 在_Layout.cshtml 布局页面中使用。

2.ViewBag.键

控制器 如下:

ViewBag.currentTime = DateTime.Now.ToShortTimeString();

ViewBag.xiaowang= new UserInfo() { Name = "小王", Password = "1234" };

视图 如下:

<h1>@ViewData["currentTime"]</h1>

<h1>@ViewBag.currentTime</h1>

<h1>@ViewBag.xiaowang.Name</h1>

相关推荐
wok1571 天前
WebMVC 和 WebFlux 架构选型
java·spring·架构·mvc
MegaDataFlowers3 天前
整合SSM框架2:CRUD功能实现
mvc
小书房3 天前
软件架构发展史之MVC/MVP/MVVM/MVI
mvc·mvvm·mvp·软件架构·mvi·android软件架构
lingggggaaaa3 天前
PHP模型开发篇&MVC层&RCE执行&文件对比法&1day分析&0day验证
开发语言·学习·安全·web安全·php·mvc
EFCY1MJ904 天前
ASP.NET MVC 1.0 (五) ViewEngine 深入解析与应用实例
后端·asp.net·mvc
小江的记录本4 天前
【RabbitMQ】RabbitMQ核心知识体系全解(5大核心模块:Exchange类型、消息确认机制、死信队列、延迟队列、镜像队列)
java·前端·分布式·后端·spring·rabbitmq·mvc
小信丶6 天前
Spring MVC @SessionAttributes 注解详解:用法、场景与实战示例
java·spring boot·后端·spring·mvc
seven97_top6 天前
MVC快速入门
mvc
极创信息8 天前
信创软件安全加固指南,信创软件的纵深防御体系
java·大数据·数据库·金融·php·mvc·软件工程
hnlgzb8 天前
MVC和MVVM设计模式中对应的是什么组件?有什么对应关系?
设计模式·mvc