ASP.NET MVC 4.0 学习6-Model Binding

一,ViewData,ViewBagTempData

ASP.NET MVC架構中,通過繼承在Controller中的ViewData,ViewBag和TempData和View頁面進行資料的存取,並且適合於少量的資料傳遞。

1.1  ViewBag

ViewBag可以產生動態屬性,我們新建項目中看到ViewBag的使用方法:

Controller中賦值:ViewBag.Title=”首頁”  View中獲取值 @ViewBag.Title

1.2  ViewData

Controller中賦值:ViewData[“message”]=”This is ViewData Value”;

View頁面中取值:@ViewData[“message”]

1.3  TempData

和ViewBag,ViewData不同的是,TempData預設把資料存放於Session,

其生命週期存在於以整個Request的範圍,可以在Controller和Controller之間做資料的傳遞

  public ActionResult Index()
        {
            //ViewData
            ViewData["ViewDataValue"] = "This is ViewData Value";
            //TempData
            TempData["TempDataValue"] = "This is TempData Value";
            //ViewBag
            ViewBag.Message = "修改此範本即可開始著手進行您的 ASP.NET MVC 應用程式。";

            return View();
        }
View Code
 <hgroup class="title">
                <h1>@ViewBag.Title.</h1>
                <h2>@ViewBag.Message</h2>
                <h3>@ViewData["ViewDataValue"]</h3>
                <h3>@TempData["TempDataValue"]</h3>
                
 </hgroup>
View Code

二,  模型連接(Model Binding)

ASP.NET MVC中會使用模型連接(Model Binding)使Controller獲取View中的資料。

2.1簡單的模型連接

如下示例,View頁面有個id為Content的文本框,對應的Action中有同名的參數Content,這樣當Action被執行的時候程序會通過DefaultModelBinder類別把View頁面傳遞過來的資料傳入Action中的同名參數。

View:

@using(Html.BeginForm()){
    <div>@Html.Label("請輸入Content內容: ")<input type="text"/ name="content"></div>
    <div>@Html.Label("您輸入的內容為:")@ViewData["content"]</div>
    <input  type="submit" value="提交"/>
}

Action:

        public ActionResult TestAction(string content)
        {
            ViewData["Content"] = content;
            return View();
        }

  

我們下斷點看一下,點擊提交以後,會通過簡單的數據連接模型把content文本框中的值傳遞到TestAction的參數中,然後通過ViewData["Content"]把值取出。

2.2 FormCollection

ASP.NET MVC除了簡單的模型連接取得View頁面資料外,還可以通過FormCollection來取得整個客戶端頁面的資料。

在Action中加入FormCollection參數以後即可取得表單資料。

View:

@{
    ViewBag.Title = "TestAction";
}

<h2>TestAction</h2>

@using(Html.BeginForm()){
    <div>@Html.Label("請輸入Content內容: ")<input type="text"/ name="content"></div>
    <div>@Html.Label("您輸入的內容為:")@ViewData["content"]</div>
    <input  type="submit" value="提交"/>
}
View Code

Action:

  //FormCollection
        public ActionResult TestAction(FormCollection form)
        {
            ViewData["Content"] = form["content"];
            return View();
        }
View Code

2.3複雜模型連接

1,我們添加TestFormModel類,類中定義三個屬性

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.ComponentModel.DataAnnotations;

namespace MvcApplication3.Models
{
    public class TestFormModel
    {
       
        public string Content { get; set; }
       
        public string UserID { get; set; }

        public int Age { get; set; }
    }
}
View Code

2,Action參數更改為TestFormModel類別,來接收View頁面傳遞過來的Form表單,

     只要Form表單裏面的欄位名稱和Model類別中的屬性一一對應,即可完成接收動作

View:

@{
    ViewBag.Title = "TestForm";
}

<h2>TestForm</h2>
@using (Html.BeginForm())
{
    <div>
        @Html.Label("请输入Content内容:")
        <input name="content" type="text" />
    </div>
    <div>@Html.Label("请输入UserID:")<input name="UserID" type="text" /></div>
   
    <input type="submit" value="提交" />
    <div>
        您提交的内容为:content= @ViewData["Content"]
        <br />
        userID= @ViewData["UserID"]
    </div>
}
View Code

Action,記得添加引用Model

    //複雜模型连接
        public ActionResult TestForm(TestFormModel form)
        {
            ViewData["Content"] = form.Content;
            ViewData["UserID"] = form.UserID;

            return View();
        }
View Code

3,View頁面輸入的值通過Form表單以Model類的格式傳遞到Controller之後,通過ViewData讀出來

   

我們下斷點調試可以看到,數據的傳遞:

2.4 判斷模型驗證結果

上一個例子我們看到View中的Form表單數據默認和Model類中的屬性一一對應,這樣我們就可以把數據驗證的部分放到Model中進行處理。

Controller中在處理模型連接的時候,程序會自動處理模型驗證的工作,驗證的結果儲存與ModelState物件中。

現在我們更新Model中的屬性,前面加[Required]表示這個屬性必須有值的時候ModelState. IsValid==true

 

Model:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.ComponentModel.DataAnnotations;

namespace MvcApplication3.Models
{
    public class TestFormModel
    {
        [Required]
        public string Content { get; set; }
        [Required]
        public string UserID { get; set; }
        [Required]
        public int Age { get; set; }
    }
}

View:

@{
    ViewBag.Title = "TestForm";
}

<h2>TestForm</h2>
@using (Html.BeginForm())
{
    <div>
        @Html.Label("请输入Content内容:")
        <input name="content" type="text" />
    </div>
    <div>@Html.Label("请输入UserID:")<input name="UserID" type="text" /></div>
   
    <input type="submit" value="提交" />
    <div>
        您提交的内容为:content= @ViewData["Content"]
        <br />
        userID= @ViewData["UserID"]
    </div>
    <div>Model中的數據驗證狀態:@ViewData["Message"]</div>
}

Action:當兩個文本框都輸入值的時候,驗證成功 否則失敗

   ////模型验证
        public ActionResult TestForm(TestFormModel form)
        {
            if (ModelState.IsValid)
            {
                //Model中的数据符合规范
                ViewData["Message"] = "驗證通過";
                ViewData["Content"] = form.Content;
                ViewData["UserID"] = form.UserID;
            }
            else
            {
                ViewData["Message"] = "驗證失敗";
            }
            return View();
        }

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。