.NET Core MVC基础之页面传值方式📃

  • .NET Core MVC基础之页面传值方式📃已关闭评论
  • 83 次浏览
  • A+
所属分类:.NET技术
摘要

最近工作太忙了,浅浅更新一下.NET基础知识。大部分面试官都会问.NET页面传值的几种方式,那么接下来就来细讲与实现一下吧!


.NET Core MVC基础之页面传值方式?

前言

最近工作太忙了,浅浅更新一下.NET基础知识。大部分面试官都会问.NET页面传值的几种方式,那么接下来就来细讲与实现一下吧!

页面传值分成两类

  • 第一类:控制器给视图传值
  • 第二类:视图给控制器传值

本篇文章主要讲控制器给视图传值

控制器->视图

弱类型数据

ViewData

ViewData是一个字典对象,可以在控制器中存储键值对,然后在视图中读取这些值。

ViewData 是通过 string 键访问的 ViewDataDictionary 对象

控制器:

public ActionResult Index() {     ViewData["Message"] = "Hello, World!";     return View(); } 

视图:

<div class="text-center">     <h1 class="display-4">@ViewData["Message"]</h1> </div> 

效果图:

.NET Core MVC基础之页面传值方式📃

ViewBag

ViewBag是一个动态属性,可以在控制器中动态添加属性,并在视图中读取这些属性。

控制器:

public IActionResult Index() {     ViewBag.Message = "你好,加班的码农!";     return View(); } 

视图:

<div class="text-center">     <h1 class="display-4">@ViewBag.Message</h1> </div> 

效果图:

.NET Core MVC基础之页面传值方式📃

TempData

用于在请求之间临时存储数据的一种机制。它类似于Session,但与Session不同的是,TempData的数据只在当前请求和下一个请求之间有效,之后就会被自动清除。

TempData 使用场景:

  • 在多个请求需要数据的情况下对重定向很有用。
  • 使用 cookie 或会话状态通过 TempData 提供程序进行实现。

控制器:

public ActionResult Index() {     return View(); }  public ActionResult NextPage() {      TempData["Message"] = "你有加班费吗,就加班?";     return RedirectToAction("Index"); } 

Index视图:

<div class="text-center">     <h1 class="display-4">@TempData["Message"]</h1> </div> 

效果图:

直接访问Index视图

.NET Core MVC基础之页面传值方式📃

访问控制器中的NextPage方法进行重定向

.NET Core MVC基础之页面传值方式📃

强类型数据

Model

Model是将数据传递给视图的最常用方式。在控制器中创建一个模型对象,并将数据赋值给模型的属性。然后在视图中声明模型类型,并使用@Model来读取实体

控制器:

public class User {     public string UserName { get; set; } }  public IActionResult Index() {     User u = new User();     u.UserName = "加班人";     return View(u); } 

视图:

@model User  <div class="text-center">     <h1 class="display-4">@Model.UserName</h1> </div> 

也可以传递集合

public IActionResult Index() {     List<User> list = new List<User>()     {         new User() { UserName = "打工人1号" },         new User() { UserName = "打工人2号" }     };     return View(list); } 
@model List<User>  <div class="text-center">     @foreach (var m in Model)     {         <h1 class="display-4">@m.UserName</h1>     } </div> 

效果图:

.NET Core MVC基础之页面传值方式📃

参考链接

ASP.NET Core MVC 中的视图 | Microsoft Learn