ASP.net数据从Controller传递到视图

最常见的方式是使用模型或 ViewBag。

  1. 使用模型传递数据:

在控制器中,创建一个模型对象,并将数据赋值给模型的属性。然后将模型传递给 View 方法。

csharp 复制代码
public class HomeController : Controller
{
    public IActionResult Index()
    {
        // 创建模型对象
        var model = new MyModel();
        
        // 将数据赋值给模型的属性
        model.Name = "T";
        model.Age = 18;
        
        // 将模型传递给视图
        return View(model);
    }
}

在视图中,通过在视图顶部声明模型类型,并使用模型属性访问数据。

html 复制代码
@model MyModel

<h1>Welcome, @Model.Name!</h1>
<p>Your age is: @Model.Age</p>
  1. 使用 ViewBag 传递数据:

在控制器中,使用 ViewBag 对象将数据存储在动态属性中,并在视图中访问这些属性。

csharp 复制代码
public class HomeController : Controller
{
    public IActionResult Index()
    {
        // 使用 ViewBag 存储数据
        ViewBag.Name = "T";
        ViewBag.Age = 18;
        
        // 将数据传递给视图
        return View();
    }
}

在视图中,使用 ViewBag 对象访问控制器中设置的属性。

html 复制代码
<h1>Welcome, @ViewBag.Name!</h1>
<p>Your age is: @ViewBag.Age</p>

3.ViewData 对象。ViewData 是一个字典类型的属性,可以用于存储和传递数据。

在控制器中,使用 ViewData 将数据存储在字典中,并使用键值对的方式进行存取。

csharp 复制代码
public class HomeController : Controller
{
    public IActionResult Index()
    {
        // 使用 ViewData 存储数据
        ViewData["Name"] = "T";
        ViewData["Age"] = 18;
        
        // 将数据传递给视图
        return View();
    }
}

在视图中,通过键访问 ViewData 中存储的数据。

html 复制代码
<h1>Welcome, @ViewData["Name"]!</h1>
<p>Your age is: @ViewData["Age"]</p>

使用 ViewData 的优点是它是一个动态属性,存储任意类型的数据。在视图中访问 ViewData 时需要进行类型转换。

综上:

  1. 使用模型:创建一个模型对象,并将数据赋值给模型的属性,然后将模型传递给视图。

  2. 使用 ViewBag:使用 ViewBag 对象将数据存储在动态属性中,并在视图中访问这些属性。

  3. 使用 ViewData:使用 ViewData 字典将数据存储在键值对中,并在视图中通过键访问这些数据。

相关推荐
忧郁的蛋~2 天前
.NET实现多任务异步与并行处理的详细步骤
后端·c#·asp.net·.net·.netcore
William_cl4 天前
ASP.NET MVC 前置基础:宿主环境 & HttpRuntime 管道,从部署到流程拆透(附避坑指南)
后端·asp.net·mvc
合作小小程序员小小店8 天前
Web渗透之身份认证与访问控制缺陷(越权(水平垂直),访问控制(没有验证),脆弱验证(Cookie,JWT,Session等))
安全·web安全·网络安全·asp.net·网络攻击模型
FuckPatience9 天前
HTTP Error 5OO.0- ASPNET Core lIS hosting failure (in-process)
asp.net
CsharpDev-奶豆哥10 天前
ASP.NET中for和foreach使用指南
windows·microsoft·c#·asp.net·.net
FuckPatience10 天前
前后端分离项目部署完成后 前后端交互过程
vue.js·asp.net
FuckPatience11 天前
前端Vue 后端ASP.NET Core WebApi 本地调试交互过程
前端·vue.js·asp.net
.NET修仙日记11 天前
2025年ASP.NETMVC面试题库全解析
面试·职场和发展·c#·asp.net·mvc·面试题·asp.net mvc
不学习何以强国11 天前
Cool Unix + OpenAuth.Net 实现一款校园小程序的开发
mysql·前端框架·asp.net
她说彩礼65万13 天前
Asp.net core appsettings.json` 和 `appsettings.Development.json`文件区别
后端·json·asp.net