zoukankan      html  css  js  c++  java
  • MVC-03 控制器(3)

        Controller负责处理浏览器来的所有要求,并决定响应什么属性给浏览器,以及协调Model与View之间的数据传递。在ASP.NET MVC中有好几种传递数据给视图的方式,例如从ASP.NET MVC 1.0就有的ViewData与TempData对象,还有从ASP.NET MVC 3.0开始提供的ViewBag对象,通过这些对象都可以将数据顺利地传到视图里,让视图页面可以取用这些从Controller传来的数据。

    六、ViewData、ViewBag与TempData概述

    1. ViewData

         当你使用ViewResult来运行结果时,可以在Action里面利用ControllerBase类别中的ViewData属性来保存数据,以便这些数据可以传递给View使用。

         在设置ViewData属性时,传入的key必须为字符串类型,而属性部分可以保存任意对象信息。

         ViewData的特性是它只会存在这次的HTTP请求中,而不会像Session将数据带到下一个HTTP请求。

    2. ViewData.Model

        由于使用ViewData字典在传入时属于“弱类型”的方式保存,也就是在ViewData里特定键值的类型永远是object通用对象类型,传给View使用之后,还必须通过转型才能进一步使用,所以用起来不太方便。

        在ASP.NET MVC的View相关技术里,可以将特定视图页面声明为某种类型,让整个视图页面参考特定类型,并且让Controller传来的Model数据直接自动转型为View所声明的类型,而这个从Controller传来的Model数据就是通过ViewData.Model传过来的。

        以下程序代码演示可以将数据通过ViewData.Model传递给View的Model使用:

            public ActionResult Index()
            {
                var data = GetDataFromDB();
                ViewData.Model = data;
                return View();
            }

        上述这段程序代码与以下这段程序代码的结果是完全一样的,都是将ViewData.Model传给View页面使用:

            public ActionResult Index()
            {
                var data = GetDataFromDB();
                return View(data);
            }

        从VS2012的快捷提示中,可以发现ViewData.Model也是object类型,为什么说这个跟“强类型”有关呢?

        当你通过ViewData.Model传递数据到视图页面,在视图页面里可以也用@model声明一个该视图页面专属的数据模型类型,声明后就可以在视图页面中取用@Model对象,而@Model对象就会拿Controller里设置好的ViewData.Model数据,并且自动转型为@model声明的类型。

        声明完成后,我们在视图页面就可以以具有类型@Model的对象进行开发,享受VS2012里使用Intellisense的方便性。

    3. ViewBag

        ViewBag被声明为一个dynamic动态类型,并且属性是一个传入ViewData的DynamicViewDataDictionary动态ViewData字典。严格上来说,ViewBag并没有什么特殊之处,因为所有对ViewBag属性的任何访问动作,最终都还是对ViewData来进行操作,唯一的差别仅在于ViewBag是dynamic动态类型而已,优点是可以少输入几个字符。例如以下ViewData的写法:

    ViewData["Message"]="更改此模板即可开始着手进行您的ASP.NET MVC应用程序。"

        换成ViewBag的写法则如下:

    ViewBag.Message="更改此模板即可开始着手进行您的ASP.NET MVC应用程序。";

     4.TempData

        TempData的数据结构与ViewData一样都是字典类型,但TempData的类型是TempDataDictionary。

        不过,TempData还是有那么一点不同的地方,在于它的内部是使用Session来保存信息,更有趣的是它的名称与特性。“Temp”是暂存的意思,但是保存在TempData中的信息会暂存多久呢?答案是:一次网页请求。

        接下来,我们用以下演示来解释“一次网页请求”的定义,在窗体数据送出到以下Action保存,如果发生数据库新增失败的消息,我们会希望这次送出的数据可以保留至下一页,此时,就会将这个只希望出现一次的消息保存到TempData中,并在下一页进行取用。

            public ActionResult Index()
            {
                TempData["T1"]="123";
                //string tmp = TempData["T1"].ToString();
                return View();
            }
    
            public ActionResult About()
            {
                ViewData["T1"] = TempData["T1"];
                return View();
            }

           以上代码,能在About动作中使用ViewData["T1"]。但如果在Index动作中添加string tmp = TempData["T1"].ToString();,则程序出错。

           在我们的电子商务网站案例中,也有TempData的使用,大家找找看。电子商务网站案例下载链接为http://yunpan.cn/QU9XTyaduYYRS

  • 相关阅读:
    Django-models,继承AbstractUser类
    Django-views,用户认证,login_requierd()
    django前篇
    jquery插件
    jquery事件及插件
    jquery操作元素
    jquery选择器筛选器
    js作用域与作用域链
    js之DOM(二)
    bootstrap
  • 原文地址:https://www.cnblogs.com/meetyy/p/3454809.html
Copyright © 2011-2022 走看看