关于asp.net MVC 中的TryUpdateModel方法

有比较才会有收货,有需求才会发现更多。

在传统的WebFormk开发工作中,我们常常会存在如下的代码块

        //保存
        protected void btnSubmit_Click(object sender, EventArgs e)
        {
            try
            {
                BLL.MoneyBll cun = new BLL.MoneyBll();
                Model.Money m1 = new Model.Money();
                m1.Commany = int.Parse(this.Commany.Text);
                m1.CountryId = int.Parse(this.cou.Value);
                m1.CountryIds = "";
                m1.MaxX = float.Parse(this.MaxX.Text);
                m1.MinX = float.Parse(this.MinX.Text);
                if (!string.IsNullOrEmpty(this.XPrice.Text)) 
                {
                    m1.XPrice = float.Parse(this.XPrice.Text);
                }
                if (!string.IsNullOrEmpty(this.YPrice.Text))
                {
                    m1.YPrice = float.Parse(this.YPrice.Text);
                }
                m1.Type = int.Parse(this.Type.Text);
                int res = cun.Add(m1);
                //JscriptMsg("添加费用信息成功!", "moneyList.aspx", "Success", "parent.loadMenuTree");
            }
            catch 
            {
                //JscriptMsg("添加费用信息失败,请检查录入合法性!", "moneyList.aspx", "Error", "parent.loadMenuTree");
            }
        }

即:在点击保存按钮的时候将表单Form内个表单元素的值一一获取,转换为相对应的目标类型,赋值到一个新的实体类对象属性上,用于实现相关的功能点开发。

以上的代码块在我们日常的开发工作中频频出现,相似程度可谓高之又高。

在mvc中为该情况的通用带来了优良的解决方案,——TryUpdateModel  用法如下

            FunModel model = new FunModel();
            TryUpdateModel(model, formCollection.AllKeys);

其中

formCollection.AllKeys是可选参数,如果未传入该参数,TryUpdateModel会获取当前请求上下文中所有的key值,包括Request.QueryString(eg:a.aspx?a=1&b=2)中的key值,以及Request.Form中所有的key值,还包括整个请求上下文中所有的数据包键值对中的健,
然后循环这些所有的健,通过反射机制获取实体对象model对应key的属性,判断如果存在名称为key的属性,那么获取数据包键值对中改key对应的value值,通过的反射的形式赋值到实体类的对应属性中去,完成数据包内数据到实体对象的装配,在此过程之中同样存在数据包中的value值到实体对象属性Type的类型转换,省略了繁琐的int.Parse(this.Commany.Text)判断,转型操作,大大简化了功能开发中类似代码的出现。formCollection.AllKeys————————Request.Form中所有的key值。


 

关于asp.net MVC 中的TryUpdateModel方法,布布扣,bubuko.com

关于asp.net MVC 中的TryUpdateModel方法

上一篇:EXCEL 文件导入SQL 中


下一篇:腾讯云上搭建MySql并且远程连接的解决方案