成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

淺析ASP.NET MVC中Controller與View數據傳遞

開發 后端
在這里我們將討論的是ASP.NET MVC中Controller與View之間的數據傳遞,希望對大家有所幫助。

在ASP.NET MVC中,經常會在Controller與View之間傳遞數據,因此,熟練、靈活的掌握這兩層之間的數據傳遞方法就非常重要。本文從兩個方面進行探討:

#T#

◆Controller向View傳遞數據

◆View向Controller傳遞數據

一、Controller向View傳遞數據

1. 使用ViewData傳遞數據

我們在Controller中定義如下:

  1. ViewData[“Message”] = “Hello word!”; 

然后在View中讀取Controller中定義的ViewData數據,代碼如下:

  1. <% = Html.Encode(ViewData[“Message”]) %> 

2. 使用TempData傳遞數據

我們在Controller中定義如下:

  1. TempData[“Message”] = “Hello word!”; 

然后在View中讀取Controller中定義的TempData數據,代碼如下:

  1. <% = Html.Encode(TempData [“Message”]) %> 

3.使用Model傳遞數據

使用Model傳遞數據的時候,通常在創建View的時候我們會選擇創建強類型View如下圖所示:

創建強類型的View以后,View的***行代碼如下所示:

  1. <%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<MvcInduction.Models.People>" %> 
  2. <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層做如下定義:

  1. <% using (Html.BeginForm("ActionName", "ControllerName"))  
  2.        { %> 
  3.     UserName:<% Html.TextBox("UserName"); %> 
  4.     Password:<% Html.TextBox("Password"); %> 
  5. <%} %> 

注意:ActionName為對應的Action名,ControllerName為對應的Controller名稱

然后在Controller層,通過Request.Form讀取表單數據的代碼如下所示:

  1. [AcceptVerbs(HttpVerbs.Post)]  
  2.         public ActionResult ActionName()  
  3.         {  
  4.             string username = Request.Form["UserName"];  
  5.             string password = Request.Form["Password"];  
  6.             return View();  

2. 通過FormCollection讀取表單數據

我們在View層做如下定義:

  1. <% using (Html.BeginForm("ActionName", "ControllerName"))  
  2.        { %> 
  3.     UserName:<% Html.TextBox("UserName"); %> 
  4.     Password:<% Html.TextBox("Password"); %> 
  5. <%} %> 

然后在Controller層,通過FormCollection讀取表單數據的代碼如下所示:

  1. [AcceptVerbs(HttpVerbs.Post)]  
  2.         public ActionResult ActionName(FormCollection formCollection)  
  3.         {  
  4.             string username = formCollection["UserName"];  
  5.             string password = formCollection["Password"];  
  6.             return View();  
  7.         } 

3.  自定義數據綁定

自定義數據綁定的方法如下:創建一個自定義數據綁定類,讓這個類繼承自IModelBinder,實現該接口中的BindModel方法。
由于寫作倉促,代碼未列出。敬請見諒。

總結:雖然我們可以通過Request.Form或FormCollection方式讀取表單數據,可是通常這兩種方式都比較繁瑣,在強類型View的情況下,我們通常會使用Controller 基類的內置方法UpdateModel(),該方法支持使用傳入的表單參數更新對象的屬性,它使用反射機制來解析對象的屬性名稱,接著基于客戶端傳入的參數值自動賦值給對象相關屬性。

以下是我寫的一個Demo的一段使用UpdateModel的代碼例子:

使用UpdateModel()的代碼例子

  1. [AcceptVerbs(HttpVerbs.Post)]  
  2.         public ActionResult Edit(int id, FormCollection collection)  
  3.         {  
  4.             //Users user = userRepository.GetUser(id);  
  5.             //user.UserName = Request.Form["UserName"];  
  6.             //user.Password = Request.Form["Password"];  
  7.             //user.Telephone = Request.Form["Telephone"];  
  8.             //user.Address = Request.Form["Address"];  
  9.             //上述方法有一點繁瑣,特別是增加異常處理邏輯之后。
  10. 一個更好的方法是使用Controller 基類的內置方法UpdateModel()。
  11. 該方法支持使用傳入的表單參數更新對象的屬性,它使用反射機制來解析對象的屬性名稱,
  12. 接著基于客戶端傳入的參數值自動賦值給對象相關屬性。  
  13.             Users user = userRepository.GetUser(id);  
  14.             string[] allowedProperties = new[] { "UserName""Password""Telephone""Address" };  
  15.                 UpdateModel(user, allowedProperties);  
  16.                 userRepository.Save();  
  17.  
  18.                 return RedirectToAction("Details"new { id = user.ID });  
  19.         } 

原文標題:ASP.NET MVC中Controller與View之間的數據傳遞總結

鏈接:http://www.cnblogs.com/wlb/archive/2009/12/10/1621475.html

責任編輯:彭凡 來源: 博客園
相關推薦

2009-07-31 12:43:59

ASP.NET MVC

2009-07-23 14:31:20

ASP.NET MVC

2009-04-08 09:58:07

ASP.NET MVCTempData框架

2009-07-20 10:33:02

ASP.NET MVC

2011-04-14 09:19:22

ASP.NET MVC

2009-09-24 09:26:22

ASP.NET MVC

2011-07-13 09:31:48

ASP.NET數據傳遞

2009-08-03 18:35:51

ASP.NET數據緩存

2009-08-05 15:50:13

ASP.NET優點

2009-07-24 15:47:35

ASP.NET與ASP

2009-12-02 09:07:45

ASP.NET 4.0

2009-11-02 10:15:53

ASP.NET MVC

2009-07-30 13:45:40

ASP.NET開發模式MVC模式

2009-08-05 18:36:12

ASP.NET Che

2009-07-24 13:41:15

ASP.NET AJA

2010-03-26 09:16:44

2009-08-10 13:32:15

ASP.NET TimASP.NET組件設計

2009-07-28 14:10:14

2010-03-19 09:17:16

ASP.NET MVC

2009-12-16 09:16:53

ASP.NET頁面間數
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲精品久久久久中文字幕欢迎你 | 久久视频精品 | 亚洲精品成人网 | 在线看无码的免费网站 | 大香在线伊779 | 亚洲精品白浆高清久久久久久 | 蜜臀网 | 欧美精品日韩精品国产精品 | 亚洲欧美日韩在线一区二区 | 九色国产| 欧美日韩亚 | 蜜桃五月天 | 成人免费视频网站在线看 | 亚洲国产欧美在线 | 伦理二区 | 日本三级在线 | 国产精品久久久久久久久久久久久 | 国产成人精品区一区二区不卡 | 久久精品小视频 | 国产伦精品一区二区三区高清 | 日本高清aⅴ毛片免费 | 国产精品18久久久 | 欧美日韩激情 | 日本不卡免费新一二三区 | 亚洲视频一区在线观看 | 久久精品国产久精国产 | 午夜免费观看 | 精品亚洲一区二区三区四区五区 | 国产精品久久久久久吹潮 | 激情五月综合网 | 久草视频在线播放 | 色综合久| 欧美色综合| 福利精品| 亚洲手机在线 | 国产成人99久久亚洲综合精品 | 成人日韩av | 中文字幕在线视频免费视频 | 黄网站涩免费蜜桃网站 | 夜夜夜操 | 亚洲日本免费 |