• ViewData、ViewBag和TempData比较


    一、ViewData、ViewBag和TempData的定义

    public dynamic ViewBag { get; }  
    public ViewDataDictionary ViewData { get; set; } 
    public TempDataDictionary TempData { get; set; }

    二、使用方法

      1、viewdata

    public ActionResult Index()
    {
         ViewData["message"] = "Hello Word!";
         return View();
    }

    razor视图引擎:

    @ViewData["message"]

      2、viewbag

    public ActionResult Index()
    {
         ViewBag.Message = "Hello, Word";
         return View();
    }

    razor视图引擎:

    @ViewBag.Message

    三、ViewBag和ViewData的区别

    viewdata viewbag
    它是key/value字典集合 它是dynamic类型对象
    从asp.net mvc1就有了 从asp.netmvc3才有
    基于asp.netframework 3.5 基于asp.net framework4.0
    viewdata比viewbag快 viewbag比viewdata慢
    页面查询数据时需要转换合适的类型 在页面查询数据时不需要转换合适的类型
    有一些类型转换代码 可读性较好

         ViewBag的使用就相当于ViewData。

         它跟ViewData一样,都是字典值,但是内在的实现却完全不一样。
         ViewBag最大的优点就是它不需要转型就可以使用它里面的值,但ViewData需要这样:

    string message = ViewData["message"] as string;

          因为ViewBag存放的不是键值对,而是dynamic动态类型,这是ASP.NET MVC3新增的部分。动态类型非常强大,尤其是容器的使用。

          ViewBag就是封装了的ViewData,它是顺应C#4的dynamic关键字而诞生的。它可以让我们像是属性访问一样检索字典中的值,这样更加自然,这也是C#所倡导的:"可以读出来的代码"。

         ViewBag在使用上与ViewData并没有孰优孰劣的说法,但是可以肯定,ViewBag比ViewData要慢,但这个真心可以忽略。值得注意的是,ViewBag可以直接访问存储在ViewData里面的数据(因为它本来就只是封装了的ViewData)。但是,像是这样:

     ViewData["Message hehe"] = "Hello, Word";

         ViewBag就有心无力了。

    四、TempData

         TempData,就是临时数据。TempData保存在Session中,Controller每次请求的时候都会从Session中获取TempData,然后清除Session。基于这样的事实,在每次请求结束后,TempData的生命周期也就结束了。

      TempData也可以在Action之间传递:

    public ActionResult Index()
    {
        TempData["message"] = "Hello";
        return View();
    }
    
    public ActionResult About()
    {
        if ("Hello" == TempData["message"] as string)
        {
             TempData["message"] = "Hello,Word";
        }
        return View();
    }

          但必须注意,要使该行为正确,也就是TempData能够被传递给另一个Action,Index操作对应的视图就不能使用TempData,因为一旦使用就相当于一次请求,那么TempData中的值就会被清空。

  • 相关阅读:
    C++进阶
    傅雷的一生
    OJ (Online Judge)使用
    详解事件委托
    tween.js是一款可生成平滑动画效果的js动画库。tween.js允许你以平滑的方式修改元素的属性值。它可以通过设置生成各种类似CSS3的动画效果。
    利用tween,使用原生js实现模块回弹动画效果
    JS阻止链接跳转代码
    CSS display 属性
    HTML5 Canvas绘文本动画(使用CSS自定义字体)
    MySQL基础CRUD编程练习题的自我提升(1)
  • 原文地址:https://www.cnblogs.com/xbblogs/p/4876947.html
Copyright © 2020-2023  润新知