在我們討論數據庫和數據模型之前,讓我們先討論一下如何將數據從控制器傳遞給視圖。控制器類將響應請求來的URL。控制器類是給您寫代碼來處理傳入請求的地方,并從數據庫中檢索數據,并最終決定什么類型的返回結果會發送回瀏覽器。視圖模板可以被控制器用來產生格式化過的HTML從而返回給瀏覽器。
**控制器**負責給任何數據或者對象提供一個必需的視圖模板,用這個視圖模板來Render返回給瀏覽器的HTML。最佳做法是:**一個視圖模板應該永遠不會執行業務邏輯或者直接和數據庫進行交互**。相應的,一個視圖模板應該只和控制器所提供的數據進行交互。維持這種"**隔離關系**"可以幫助,保持代碼的干凈、測試性和更易維護。
當前,` HelloWorldController`類中`Welcome`操作方法需要一個`name`和一個`numTimes`參數,然后直接輸出給瀏覽器。相比只返回一個字符串,讓我們來改變控制器,來使用視圖模板吧。視圖模板將生成動態的HTML,這意味著您需要通過適當的方式把數據從控制器傳遞給視圖,從而才能生成動態的HTML。您可以把視圖模板需要的動態數據 (參數)在控制器中放入到一個`ViewBag`對象中,然后視圖模板可以訪問這個對象。
打開*HelloWorldController.cs*文件,更改`Welcome`方法,將`Message`和`NumTimes`的值添加到[ViewBag](http://rachelappel.com/when-to-use-viewbag-viewdata-or-tempdata-in-asp.net-mvc-3-applications)對象里。`ViewBag`是一個動態的對象,這意味著在您沒有給`ViewBag`放置屬性時,它沒有任何屬性,您可以把任何您想放置的對象放入到` ViewBag`對象中。 [ASP.NET MVC model binding system](http://odetocode.com/Blogs/scott/archive/2009/04/27/6-tips-for-asp-net-mvc-model-binding.aspx) 會自動將地址欄中URL里的 query string映射到您方法中的參數(`name` 和`numTimes`)。
完整的*HelloWorldController.cs*文件如下所示:
~~~
using System.Web;
using System.Web.Mvc;
namespace MvcMovie.Controllers
{
public class HelloWorldController : Controller
{
public ActionResult Index()
{
return View();
}
public ActionResult Welcome(string name, int numTimes = 1)
{
ViewBag.Message = "Hello " + name;
ViewBag.NumTimes = numTimes;
return View();
}
}
}
~~~
現在`ViewBag`對象包含了數據,并將自動傳遞給視圖模板。 接下來,您需要一個歡迎視圖模板 !在**生成**菜單中,選擇**生成 MvcMovie (快捷鍵 Ctrl+Shift+B)**,以確保項目編譯成功。
在*Views\HelloWorld*文件夾上,右鍵單擊”**添加(視圖)”**,選擇*”MVC 5 View Page with (Layout Razor).”*
[](http://images.cnitblog.com/blog/139239/201312/17165714-015676fe4f634718a0db91799f98a914.png)
在 “**指定項名稱 (Specify Name for Item )**” 對話框, 輸入”**Welcome**”, 點擊“**確定(OK)**”.????
在“**選擇布局(the Select a Layout Page)**”對話框,接受缺省的”**布局_Layout.cshtml**”,并點擊“**確定(OK)**”.????
[](http://images.cnitblog.com/blog/139239/201312/17165718-8d46574d84fd4156b2fceba30af85161.png)
*MvcMovie\Views\HelloWorld\Welcome.cshtml*文件創建成功。
在Welcome.cshtml文件里替換標記, 您將創建一個循環,循環說多次“Hello”。
下面顯示了完整的*Welcome.cshtml*文件。
~~~
@{
ViewBag.Title = "Welcome";
}
<h2>Welcome</h2>
<ul>
@for (int i = 0; i < ViewBag.NumTimes; i++)
{
<li>@ViewBag.Message</li>
}
</ul>
~~~
運行應用程序,并瀏覽下面的 URL : *http://localhost:xx/HelloWorld/Welcome?name=Scott&numtimes=4*
現在,[模型綁定](http://odetocode.com/Blogs/scott/archive/2009/04/27/6-tips-for-asp-net-mvc-model-binding.aspx)(model binder) 使得數據從URL傳遞給控制器。控制器將數據裝入到`ViewBag`對象中,通過該對象傳遞給視圖。然后視圖為用戶生成顯示所需的HTML。
[](http://images.cnitblog.com/blog/139239/201312/17165720-055f5bd37a64404882a6ef835c9e9d82.png)
在上面的示例中,我們使用了`ViewBag`對象把數據從控制器傳遞給了視圖。在本系列教程后面的文章中,我們將使用視圖模型來將數據從一個控制器傳遞到視圖中。用視圖模型來傳遞數據,這一般是首選的辦法。Blog[Dynamic V Strongly Typed Views](http://blogs.msdn.com/b/rickandy/archive/2011/01/28/dynamic-v-strongly-typed-views.aspx) 有更加詳細的介紹。
到這里,這是一種"M"模型,但不是數據庫的那種“M”模型。讓我們來創建一個電影數據庫吧。
- 前言
- 入門介紹
- 添加一個控制器
- 添加一個視圖
- 添加一個模型
- 從控制器訪問數據模型
- 驗證編輯方法和編輯視圖
- 給電影表和模型添加新字段
- 給數據模型添加校驗器
- 查詢詳細信息和刪除記錄
- 第三方控件Studio for ASP.NET Wijmo MVC4 工具應用
- ASP.NET MVC 5-開始MVC5之旅
- 控制器
- 視圖
- 將數據從控制器傳遞給視圖
- 添加一個模型
- 創建連接字符串(Connection String)并使用SQL Server LocalDB
- 從控制器訪問數據模型
- 驗證編輯方法(Edit method)和編輯視圖(Edit view)
- 給電影表和模型添加新字段
- 給數據模型添加校驗器
- 查詢Details和Delete方法