在ASP.NET MVC中,經常會在Controller與View之間傳遞數據,因此,熟練、靈活的掌握這兩層之間的數據傳遞方法就非常重要。本文從兩個方面進行探討:
??Controller向View傳遞數據
??View向Controller傳遞數據
HTML獲取JAVA后端發來的數據??
一、Controller向View傳遞數據
1.?????? 使用ViewData傳遞數據
我們在Controller中定義如下:
ViewData[“Message”] = “Hello word!”;
然后在View中讀取Controller中定義的ViewData數據,代碼如下:
<% = Html.Encode(ViewData[“Message”]) %>
2.?????? 使用TempData傳遞數據
我們在Controller中定義如下:
TempData[“Message”] = “Hello word!”;
然后在View中讀取Controller中定義的TempData數據,代碼如下:
<% = Html.Encode(TempData [“Message”]) %>
3.?????? 使用Model傳遞數據
使用Model傳遞數據的時候,通常在創建View的時候我們會選擇創建強類型View如下圖所示:
創建強類型的View以后,View的第一行代碼如下所示:
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<MvcInduction.Models.People>" %>
?
<MvcInduction.Models.People>就代表了這個View使用的Model為“MvcInduction.Models.People”
?
總結:
1.???????? ViewData與TempData方式是弱類型的方式傳遞數據,而使用Model傳遞數據是強類型的方式。
2.???????? ViewData與TempData是完全不同的數據類型,ViewData數據類型是ViewDataDictionary類的實例化對象,而TempData的數據類型是TempDataDictionary類的實例化對象。
3.???????? TempData實際上保存在Session中,控制器每次執行請求時都會從Session中獲取TempData數據并刪除該Session。TempData數據只能在控制器中傳遞一次,其中的每個元素也只能被訪問一次,訪問之后會被自動刪除。
4.???????? ViewData只能在一個Action方法中進行設置,在相關的視圖頁面讀取,只對當前視圖有效。理論上,TempData應該可以在一個Action中設置,多個頁面讀取。但是,實際上TempData中的元素被訪問一次以后就會被刪除。
?
二、View向Controller傳遞數據
在ASP.NET MVC中,將View中的數據傳遞到控制器中,主要通過發送表單的方式來實現。具體的方式有:
1.???????? 通過Request.Form讀取表單數據
我們在View層做如下定義:
<% using (Html.BeginForm("ActionName", "ControllerName"))
?????? { %>
??? UserName:<% Html.TextBox("UserName"); %>
??? Password:<% Html.TextBox("Password"); %>
<%} %>
注意:ActionName為對應的Action名,ControllerName為對應的Controller名稱
然后在Controller層,通過Request.Form讀取表單數據的代碼如下所示:
[AcceptVerbs(HttpVerbs.Post)]
??????? public ActionResult ActionName()
???? ???{
??????????? string username = Request.Form["UserName"];
??????????? string password = Request.Form["Password"];
??????????? return View();
}
2.?????? 通過FormCollection讀取表單數據
我們在View層做如下定義:
<% using (Html.BeginForm("ActionName", "ControllerName"))
?????? { %>
??? UserName:<% Html.TextBox("UserName"); %>
??? Password:<% Html.TextBox("Password"); %>
<%} %>
然后在Controller層,通過FormCollection讀取表單數據的代碼如下所示:
[AcceptVerbs(HttpVerbs.Post)]
??????? public ActionResult ActionName(FormCollection formCollection)
??????? {
??????????? string username = formCollection["UserName"];
??????????? string password = formCollection["Password"];
??????????? return View();
??????? }
?3.?????? 自定義數據綁定
自定義數據綁定的方法如下:創建一個自定義數據綁定類,讓這個類繼承自IModelBinder,實現該接口中的BindModel方法。
由于寫作倉促,代碼未列出。敬請見諒。
?
總結:雖然我們可以通過Request.Form或FormCollection方式讀取表單數據,可是通常這兩種方式都比較繁瑣,在強類型View的情況下,我們通常會使用Controller 基類的內置方法UpdateModel(),該方法支持使用傳入的表單參數更新對象的屬性,它使用反射機制來解析對象的屬性名稱,接著基于客戶端傳入的參數值自動賦值給對象相關屬性。
以下是我寫的一個Demo的一段使用UpdateModel的代碼例子:
????????public?ActionResult?Edit(int?id,?FormCollection?collection)
????????{
????????????//Users?user?=?userRepository.GetUser(id);
????????????//user.UserName?=?Request.Form["UserName"];
????????????//user.Password?=?Request.Form["Password"];
????????????//user.Telephone?=?Request.Form["Telephone"];
????????????//user.Address?=?Request.Form["Address"];
????????????//上述方法有一點繁瑣,特別是增加異常處理邏輯之后。一個更好的方法是使用Controller?基類的內置方法UpdateModel()。該方法支持使用傳入的表單參數更新對象的屬性,它使用反射機制來解析對象的屬性名稱,接著基于客戶端傳入的參數值自動賦值給對象相關屬性。
????????????Users?user?=?userRepository.GetUser(id);
????????????string[]?allowedProperties?=?new[]?{?"UserName",?"Password",?"Telephone",?"Address"?};
????????????????UpdateModel(user,?allowedProperties);
????????????????userRepository.Save();
????????????????return?RedirectToAction("Details",?new?{?id?=?user.ID?});
????????}