zoukankan      html  css  js  c++  java
  • ASP.NET MVC学习---(六)CRUD例子补充

    在之前,我们使用mvc做了一个crud的小例子

    整个项目过程应该是能够很容易理解的

    通过这个例子我们可以大概的了解mvc的基本使用方法

    但是由于篇幅限制(还不如说自己懒不想写那么长...)

    没有能够在上一篇的例子中涉及到比较详细的知识点

    所有在这里做出补充

    如果有遗漏或者不同理解的地方希望各位同学给出宝贵的意见~


    1.action方法接收浏览器发送过来的参数的方式

    可能有初学的同学看之前的代码时会感到一头雾水

    在控制器类中的action方法参数中

    怎么一会只要一个int id就可以

    一会又要用什么实体对象来传递

    到底什么时候用什么方式呢?

    (1)根据路由配置来为action方法传递参数

    例如上个例子中的路由规则是这样子的

    url: "{controller}/{action}/{id}"

    那么想要给action方法传递id参数(且必须明确是id参数)就可以直接写在url地址最后

    action方法参数中只要有int id(这个id必须和路由配置里面的id是同名的)就可以自动接收到

    可见,此方法用于传递类似id这样的参数很方便快捷,但是只能根据路由中配置好的规则来传递

    (2)模型绑定

    在crud的例子中我们已经提到过模型绑定

    前台提交数据标签的name属性 和 后台实体类的属性名 一致

    那么就可以在action方法中直接通过一个 实体类变量 来接收

    mvc框架会自动前台提交的数据填充到这个实体参数中

    这是个很爽很简便的参数传递方式

    至于其中是怎么自动填充的

    大概了解到是通过反射实现的

    如果有兴趣,那是那句话,google之~

    (3)通过Request键值对来接收参数

    这种方式相信大家都很熟悉

    在webform中经常使用

    Request.Form或者Request.QueryString等

    在mvc中同样可以使用

    (4)通过FormCollection类接收参数

    public ActionResult XXX(FormCollection form){...}

    在action方法中通过一个FormCollection变量来接收参数

    之后可以直接在代码中form["键"]来获得浏览器传递过来的数据

    此方法的用法和第三种方法是一样的通过键值对来操作


    2.action方法到底是什么?

    可以说在控制器类中

    我们见的最多,用的最多的就是action方法

    之前我们说过,返回值为ActionResult的方法称之为action方法

    那么这个ActionResult到底是各方神圣?

    为什么我们既可以再action方法中返回视图也可以直接返回字符等数据呢?

    我们用反编译工具来看看这个ActionResult到底是什么

    在项目的bin文件夹下找到System.Web.Mvc.dll文件拖入Reflector中

    展开程序集,找到System.Web.Mvc就会看到ActionResult

    展开节点之后看看ActionResult的子类

    现在是不是明白了一点什么?

    我们在回头看看action方法中的return Redirect和View的返回值是什么

    我们在ActionResult的子类是不是能看到RedirectResult和ViewResultBase的身影?

    这就是为什么在action方法中可以返回各种各样的数据了

    因为返回值都是ActionResult的子类

    我们甚至可以将action方法的返回值确定到一个子类,如:

    ViewResult

    //通过数据上下文将T_Users的数据查询出来
            public ViewResult Index()
            {
                //将T_Users表的数据都取出来
                var users = dbEntities.T_Users.Where(u => true).ToList();
                //并交给ViewData.Model
                //ViewData.Model = users;
    
                //通过ViewBag传递数据给前台
                ViewBag.Users = users;
                return View();
            }
    RedirectResult
    //删除方法
            public RedirectResult Delete(int id)
            {
                T_Users user = new T_Users() {Id = id};
                dbEntities.T_Users.Attach(user);
                dbEntities.T_Users.Remove(user);
                dbEntities.SaveChanges();
                return Redirect("/Home/Index");
            }


    3.返回视图的方式

    当我们在action方法中使用return View()返回视图的时候有三种情况

    (1)没有指定视图:只有return View(),这种情况mvc会默认加载本控制器文件夹下与action方法同名的视图

    (2)指定本控制器下的另外一个视图:return View(”视图名“) mvc会加载本控制器文件夹下的该视图

    (3)指定另外一个控制器文件夹下的视图:return View("~/xxx控制器文件夹/xxx.cshtml") 注意,使用这种方式要指定绝对路径,且要加上.cshtml后缀名


    4.前后台传递参数的方式

    (1)弱类型的ViewData

    可以用键值对的形式为ViewData数据赋值或者取值

    (2)动态型的ViewBag

    动态添加属性传值

    (3)Model

    (4)TempData

    该方式也是通过键值对来操作,使用方法和ViewData一样

    到这里可能有有这样的疑问

    为什么在后台的ViewData或者ViewBag中赋值之后可以在前台页面中得到呢?

    我们知道后台的控制器是一个类

    其实前台的cshtml也是一个类

    但是他们之间的并不像是webform那样的继承关系

    在mvc中,前后台类并没有直接的关系

    前台类是后台的控制器类创建的

    也就是说ViewData或者ViewBag赋值之后

    在创建前台类时

    会将ViewData或者ViewBag的值传给前台类

    这其实就是一个数据传递而已

    这里有一个点很有趣

    当在后台使用ViewData["xxx"]=yyy时

    在前台通过ViewBag.xxx也能渠道yyy的值

    也就是说ViewData和ViewBag的值是共享的!

    但是ViewData的Model属性(其实就是第三中方式的Model)是不和ViewBag共享的

    而且注意,TempData中的数据也是不和其他属性共享的,TempData有着另外的作用,我们将会在以后进行讨论

    相信很多人在使用ViewBag的时候肯定觉得很神奇

    竟然可以想js代码一样随意点属性!

    通过ViewBag转到定义可以看到

    它其实是一个dynamic类型

    这是一个动态的类型

    dynamic obj=new Object();

    主要是dynamic类型的变量,我们就可以随意的动手动脚~

    它本质上其实就是一个Object类型,至于到底是怎么实现的,google在等你~



    5.强类型视图

    当我们用Model将实体对象传给前台时,最后效果是可以实现

    但是在前台使用Model取值的时候是没有智能提示的

    因为vs编译器并不确定Model是什么类型的数据

    但是如果一定要这个效果呢?

    @{
        Layout = null;
    }
    @*我们可以通过这种方式告诉编译器Model的类型,那么在后面的编码时就会出现智能提示*@
    @model MvcTest.Models.T_Users
    <!DOCTYPE html>
    这就是所谓的强类型视图

    提前为页面中的Model指定类型


    通过上面补充的知识点希望能够加强对mvc的理解和印象~

    下一遍Razor视图引擎语法

    将会对Razor视图引擎进一步介绍

    毕竟这可以mvc的招牌菜之一~

    敬请期待~

  • 相关阅读:
    【GStreamer开发】GStreamer基础教程14——常用的element
    【GStreamer开发】GStreamer基础教程12——流
    【GStreamer开发】GStreamer基础教程12——流
    【GStreamer开发】GStreamer基础教程11——调试工具
    【GStreamer开发】GStreamer基础教程11——调试工具
    【GStreamer开发】GStreamer基础教程10——GStreamer工具
    【GStreamer开发】GStreamer基础教程10——GStreamer工具
    【GStreamer开发】GStreamer基础教程09——收集媒体信息
    【GStreamer开发】GStreamer基础教程08——pipeline的快捷访问
    【GStreamer开发】GStreamer基础教程08——pipeline的快捷访问
  • 原文地址:https://www.cnblogs.com/jchubby/p/4429718.html
Copyright © 2011-2022 走看看