通過第一天的學(xué)習(xí)之后,我們相信您已經(jīng)對(duì)MVC有一些基本了解。
10年積累的網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站設(shè)計(jì)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先制作網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有富拉爾基免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
本節(jié)所講的內(nèi)容是在上節(jié)的基礎(chǔ)之上,因此需要確保您是否掌握了上一節(jié)的內(nèi)容。本章的目標(biāo)是在今天學(xué)習(xí)結(jié)束時(shí)利用最佳實(shí)踐解決方案創(chuàng)建一個(gè)小型的MVC項(xiàng)目,本節(jié)的主要目標(biāo)是了解MVC之間的數(shù)據(jù)傳遞問題。我們會(huì)逐步深入講解,并添加新功能,使項(xiàng)目越來越完善。
系列文章
七天學(xué)會(huì)ASP.NET MVC (一)——深入理解ASP.NET MVC
Controller與 View之間的值傳遞
在上一節(jié)的實(shí)驗(yàn)二中已經(jīng)創(chuàng)建了靜態(tài)View。然而在實(shí)際使用情況下,View常用于顯示動(dòng)態(tài)數(shù)據(jù)。在實(shí)驗(yàn)三中們將在View中動(dòng)態(tài)顯示數(shù)據(jù)。
View將從從Controller獲得Model中的數(shù)據(jù)。
Model是MVC中 表示業(yè)務(wù)數(shù)據(jù)的層。
實(shí)驗(yàn)3 ——使用View數(shù)據(jù)
ViewData相當(dāng)于數(shù)據(jù)字典,包含Controlle和View之間傳遞的所有數(shù)據(jù)。Controller會(huì)在該字典中添加新數(shù)據(jù)項(xiàng),View從字典中讀取數(shù)據(jù)。
1. 創(chuàng)建Model 類
在Model文件夾下新建Employee類,如下。
1: public class Employee
2:
3: {
4: public string FirstName { get; set; }
5:
6: public string LastName { get; set; }
7:
8: public int Salary { get; set; }
9:
10: }
2. 在Controller 中獲取Model
在GetView 方法中創(chuàng)建Employee 對(duì)象:
1: Employee emp = new Employee();
2: emp.FirstName = "Sukesh";
3: emp.LastName="Marla";
4: emp.Salary = 20000;
注意:請(qǐng)確保使用Using語句包含此類,或者使用類的全稱。
1: using WebApplication1.Models;
3. 創(chuàng)建ViewData 并返回View
在ViewData中存儲(chǔ)Employee 對(duì)象。
1: ViewData["Employee"] = emp;
2: return View("MyView");
4. 在View中顯示Employee 數(shù)據(jù)
打開MyView.cshtml。
從ViewData中獲取Employee 數(shù)據(jù)并按照如下代碼顯示:
1: <div>
2: @{
3: WebApplication1.Models.Employee emp=(WebApplication1.Models.Employee)
4: ViewData["Employee"];
5: }
6:
7: <b>Employee Details </b><br />
8: Employee Name : @emp.FirstName@emp.LastName <br />
9: Employee Salary: @emp.Salary.ToString("C")
10: </div>
5. 測試輸出
按F5運(yùn)行
關(guān)于實(shí)驗(yàn) 3
1. 寫Razor代碼帶花括號(hào)和沒有花括號(hào)有什么區(qū)別?
在實(shí)驗(yàn)三中@emp.FirstName能夠使用以下腳本來代替
1: @{
2: Response.Write(emp.FirstName);
3: }
@符號(hào)后沒有花括號(hào)只是簡單的顯示變量或表達(dá)式的值
2. 為什么需要強(qiáng)制轉(zhuǎn)換類型
ViewData可操作內(nèi)部對(duì)象,每次添加新值,會(huì)封裝成對(duì)象類型,因此每次都需要解壓來提取值。
3. @emp.FirstName @emp.LastName有什么特殊含義?
意味著LastName顯示在FirstName之后并自動(dòng)添加空格。
4. 為什么 Employee中的 硬編碼是由Controller創(chuàng)建的 ?
在本文中只是為了實(shí)現(xiàn)實(shí)驗(yàn)?zāi)康?,因此采用硬編碼,實(shí)際使用中,是從數(shù)據(jù)庫或Web服務(wù)中獲取的。
5. 數(shù)據(jù)庫邏輯,數(shù)據(jù)訪問層,業(yè)務(wù)層分別指的是什么?
數(shù)據(jù)訪問層是ASP.NET MVC中是一直隱式存在的,MVC定義中不包含數(shù)據(jù)訪問層的定義。
業(yè)務(wù)層是解釋器的先驅(qū),是Model的一部分。
完整的MVC結(jié)構(gòu)
實(shí)驗(yàn)4——ViewBag的使用
1. 創(chuàng)建View Bag
在實(shí)驗(yàn)三的基礎(chǔ)之上,使用以下腳本代替第三步中的代碼。
1: ViewBag.Employee = emp;
2. 在View中顯示EmployeeData
使用以下代碼來替代實(shí)驗(yàn)三中第四步中的代碼:
1: @{
2: WebApplication1.Models.Employee emp = (WebApplication1.Models.Employee)
3: ViewBag.Employee;
4: }
5: Employee Details
6:
7: Employee Name: @emp.FirstName @emp.LastName
8:
9: Employee Salary: @emp.Salary.ToString("C")
3. 測試輸出
運(yùn)行結(jié)果:
關(guān)于實(shí)驗(yàn)4
可以傳遞ViewData,接收時(shí)獲取ViewBag嗎?
答案是肯定的,反之亦然。如之前所說的,ViewBag只是ViewData的一塊糖/
ViewData與ViewBag的問題
ViewData和ViewBag 是Contoller與View之間值傳遞的內(nèi)容。但是在實(shí)際使用的過程中,它們并不是最佳選擇,接下來我們來看看使用它們的缺點(diǎn):
性能問題;ViewData中的值都是對(duì)象類型,使用之前必須強(qiáng)制轉(zhuǎn)換為合適的類型。會(huì)添加額外的性能負(fù)擔(dān)。
沒有類型安全就沒有編譯時(shí)錯(cuò)誤,如果嘗試將其轉(zhuǎn)換為錯(cuò)誤的類型,運(yùn)行時(shí)會(huì)報(bào)錯(cuò)。良好的編程經(jīng)驗(yàn)告訴我們,錯(cuò)誤必須在編譯時(shí)捕獲。
數(shù)據(jù)發(fā)送和數(shù)據(jù)接收之間沒有正確的連接;MVC中,Controller和View是松散的連接的。Controller是無法捕獲View變化,View也無法捕獲到Controller內(nèi)部發(fā)生的變化。從Controller傳遞一個(gè)ViewData或ViewBag的值,當(dāng)開發(fā)人員正在View中寫入,就必須記錄從Controller中即將獲得什么值。如果Controller與View開發(fā)人員不是相同的開發(fā)人員,開發(fā)工作會(huì)變得非常困難。會(huì)導(dǎo)致許多運(yùn)行時(shí)問題,降低了開發(fā)效率。
實(shí)驗(yàn)5——理解強(qiáng)類型View
ViewData和ViewBag引起的所有問題根源都在于數(shù)據(jù)類型。參數(shù)值的數(shù)據(jù)類型是被封裝在ViewData中的,稱為對(duì)象。
如果能夠設(shè)置Controller和View之間參數(shù)傳遞的數(shù)據(jù)類型,那么上述問題就會(huì)得到解決,因此從得出強(qiáng)類型View。
接下來,我們看一個(gè)簡單的例子,如果工資大于15000則顯示***,低于顯示綠色。
1. 創(chuàng)建View的強(qiáng)類型
在View的頂部添加以下代碼:
@model WebApplication1.Models.Employee
2. 顯示數(shù)據(jù)
在View內(nèi)部輸入@Model.就會(huì)查看到Model類的屬性
添加以下代碼來顯示數(shù)據(jù):
1: Employee Details
2:
3: Employee Name : @Model.FirstName @Model.LastName
4:
5: @if(Model.Salary>15000)
6: {
7: <span >
8: Employee Salary: @Model.Salary.ToString("C")
9: </span>
10: }
11: else
12: {
13: <span >
14:
15: Employee Salary: @Model.Salary.ToString("C")
16: </span>
17: }
3. 從Controller Action方法中傳遞Model數(shù)據(jù)。
修改action代碼
1: Employee emp = new Employee();
2: emp.FirstName = "Sukesh";
3: emp.LastName="Marla";
4: emp.Salary = 20000;
5: return View("MyView",emp);
4. 測試輸出
關(guān)于實(shí)驗(yàn)5
View中使用類時(shí)需要聲明類的全稱嗎 (Namespace.ClassName)?
添加以下語句,就不需要添加全稱。
1: @using WebApplication1.Models
2: @model Employee
是否必須設(shè)置View的強(qiáng)類型View5或是不使用ViewData和ViewBag?
設(shè)置強(qiáng)類型的View是最佳解決方案。
是否能將View設(shè)置為多個(gè)Model使用的強(qiáng)類型?
不可以,實(shí)際項(xiàng)目中在一個(gè)View中想要顯示多個(gè)Model時(shí)以點(diǎn)結(jié)束的。該問題的解決方法將在下一節(jié)討論。
理解ASP.NET MVC 中的View Model
實(shí)驗(yàn)5中已經(jīng)違反了MVC的基本準(zhǔn)則。根據(jù)MVC,V是View純UI,不包含任何邏輯層。而我們?cè)趯?shí)驗(yàn)5中以下三點(diǎn)違反了MVC的體系架構(gòu)規(guī)則。
1. 附加姓和名顯示全名——邏輯層
2. 使用貨幣顯示工資——邏輯層
3. 使用不同的顏色表示工資值,使用簡單的邏輯改變了HTML元素的外觀?!壿媽?/p>
ViewModel 解決方法
ViewModel是ASP.NET MVC應(yīng)用中隱式聲明的層。它是用于維護(hù)Model與View之間數(shù)據(jù)傳遞的,是View的數(shù)據(jù)容器。
Model 和 ViewModel 的區(qū)別
Model是業(yè)務(wù)相關(guān)數(shù)據(jù),是根據(jù)業(yè)務(wù)和數(shù)據(jù)結(jié)構(gòu)創(chuàng)建的。ViewModel是視圖相關(guān)的數(shù)據(jù)。是根據(jù)View創(chuàng)建的。
具體的工作原理
Controller 處理用戶交互邏輯或簡單的判斷。處理用戶需求
Controller 獲取一個(gè)或多個(gè)Model數(shù)據(jù)
Controller 決策哪個(gè)View最符合用戶的請(qǐng)求
Controller 將根據(jù)Model數(shù)據(jù)和View需求創(chuàng)建并且初始化ViewModel對(duì)象。
Controller 將ViewModel數(shù)據(jù)以ViewData或ViewBag或強(qiáng)類型View等對(duì)象傳遞到View中。
Controller 返回View。
View 與 ViewModel 之間是如何關(guān)聯(lián)的?
View將變成ViewModel的強(qiáng)類型View。
Model和 ViewModel 是如何關(guān)聯(lián)的?
Model和ViewModel 是互相獨(dú)立的,Controller將根據(jù)Model對(duì)象創(chuàng)建并初始化ViewModel對(duì)象。
接下來我們來看實(shí)驗(yàn)6:
實(shí)驗(yàn)6—— 實(shí)現(xiàn)ViewModel
1. 新建文件夾
在項(xiàng)目中創(chuàng)建新文件夾并命名為ViewModels。
2. 新建EmployeeViewModel
為了達(dá)到實(shí)驗(yàn)?zāi)康模紫攘谐鑫覀兊膶?shí)驗(yàn)需求:
1. 名和姓應(yīng)該合并顯示。
2. 使用貨幣顯示數(shù)量
3. 薪資以不同的顏色來顯示
4. 當(dāng)前登錄用戶也需要在View中顯示。
在ViewModels類中,創(chuàng)建新類并命名為EmployeeViewModel,如下所示:
1: public class EmployeeViewModel
2: {
3: public string EmployeeName { get; set; }
4: public string Salary { get; set; }
5: public string SalaryColor { get; set; }
6: public string UserName{get;set;}
7: }
注意,姓和名應(yīng)該使用EmployeeName這一個(gè)屬性。而Salary屬性的數(shù)據(jù)類型是字符串,且有兩個(gè)新的屬性添加稱為SalaryColor和UserName。
3. View中使用ViewModel
實(shí)驗(yàn)五中已經(jīng)創(chuàng)建了View的強(qiáng)類型Employee。將它改為 EmployeeViewModel
1: @using WebApplication1.ViewModels
2: @model EmployeeViewModel
4. 在View中顯示數(shù)據(jù)
使用以下腳本代替View部分的內(nèi)容
1: Hello @Model.UserName
2: <hr />
3: <div>
4: <b>Employee Details</b><br />
5: Employee Name : @Model.EmployeeName <br />
6: <span >
7: Employee Salary: @Model.Salary
8: </span>
9: </div>
5. 新建并傳遞ViewModel
在GetView方法中,獲取Model數(shù)據(jù)并且將強(qiáng)制轉(zhuǎn)換為ViewModel對(duì)象。
1: public ActionResult GetView()
2: {
3: Employee emp = new Employee();
4: emp.FirstName = "Sukesh";
5: emp.LastName="Marla";
6: emp.Salary = 20000;
7:
8: EmployeeViewModel vmEmp = new EmployeeViewModel();
9: vmEmp.EmployeeName = emp.FirstName + " " + emp.LastName;
10: vmEmp.Salary = emp.Salary.ToString("C");
11: if(emp.Salary>15000)
12: {
13: vmEmp.SalaryColor="yellow";
14: }
15: else
16: {
17: vmEmp.SalaryColor = "green";
18: }
19:
20: vmEmp.UserName = "Admin"
21:
22: return View("MyView", vmEmp);
23: }
6. 測試輸出
盡管運(yùn)行結(jié)果類似,但是View中不包含任何業(yè)務(wù)邏輯。
關(guān)于實(shí)驗(yàn)6
是否意味著,每個(gè)Model都有一個(gè)ViewModel?
每個(gè)View有其對(duì)應(yīng)的ViewModel。
Model與ViewModel之間存在關(guān)聯(lián)是否是好的實(shí)現(xiàn)方法?
最好的是Model與ViewModel之間相互獨(dú)立。
需要每次都創(chuàng)建ViewModel嗎?假如View不包含任何呈現(xiàn)邏輯只顯示Model數(shù)據(jù)的情況下還需要?jiǎng)?chuàng)建ViewModel嗎?
建議是每次都創(chuàng)建ViewModel,每個(gè)View都應(yīng)該有對(duì)應(yīng)的ViewModel,盡管ViewModel包含與Model中相同的屬性。
假定一個(gè)View不包含任何呈現(xiàn)邏輯,只顯示Model數(shù)據(jù),我們不創(chuàng)建ViewModel會(huì)發(fā)生什么?
無法滿足未來的需求,如果未來需要添加新數(shù)據(jù),我們需要從頭開始創(chuàng)建全新的UI,所以如果我們保持規(guī)定,從開始創(chuàng)建ViewModel,就不會(huì)發(fā)生這種情況。在本實(shí)例中,初始階段的ViewModel將與Model幾乎完全相同。
實(shí)驗(yàn)7——帶有集合的View
在本實(shí)驗(yàn)中,在View中顯示Employee列表。
1. 修改EmployeeViewModel 類
刪除UserName屬性
1: public class EmployeeViewModel
2: {
3: public string EmployeeName { get; set; }
4: public string Salary { get; set; }
5: public string SalaryColor { get; set; }
6: }
2. 創(chuàng)建結(jié)合ViewModel
在ViewModels 文件下,創(chuàng)建新類并命名為EmployeeListViewModel
1: public class EmployeeListViewModel
2: {
3: public List<employeeviewmodel> Employees { get; set; }
4: public string UserName { get; set; }
5: }
3. 修改強(qiáng)類型View的類型
1: @using WebApplication1.ViewModels
2: @model EmployeeListViewModel
4. 顯示View中所有的Employee
1: <body>
2: Hello @Model.UserName
3: <hr />
4: <div>
5: <table>
6: <tr>
7: <th>Employee Name</th>
8: <th>Salary</th>
9: </tr>
10: @foreach (EmployeeViewModel item in Model.Employees)
11: {
12: <tr>
13: <td>@item.EmployeeName</td>
14: <td >@item.Salary</td>
15: </tr>
16: }
17: </table>
18: </div>
19: </body>
5. 創(chuàng)建Employee的業(yè)務(wù)邏輯
新建類并命名為EmployeeBusinessLayer ,并帶有GetEmployees()方法。
1: public class EmployeeBusinessLayer
2: {
3: public List<employee> GetEmployees()
4: {
5: List<employee> employees = new List<employee>();
6: Employee emp = new Employee();
7: emp.FirstName = "johnson";
8: emp.LastName = " fernandes";
9: emp.Salary = 14000;
10: employees.Add(emp);
11:
12: emp = new Employee();
13: emp.FirstName = "michael";
14: emp.LastName = "jackson";
15: emp.Salary = 16000;
16: employees.Add(emp);
17:
18: emp = new Employee();
19: emp.FirstName = "robert";
20: emp.LastName = " pattinson";
21: emp.Salary = 20000;
22: employees.Add(emp);
23:
24: return employees;
25: }
26: }
27: </employee></employee></employee>
6.從控制器中傳參
1: public ActionResult GetView()
2: {
3: EmployeeListViewModel employeeListViewModel = new EmployeeListViewModel();
4:
5: EmployeeBusinessLayer empBal = new EmployeeBusinessLayer();
6: List<employee> employees = empBal.GetEmployees();
7:
8: List<employeeviewmodel> empViewModels = new List<employeeviewmodel>();
9:
10: foreach (Employee emp in employees)
11: {
12: EmployeeViewModel empViewModel = new EmployeeViewModel();
13: empViewModel.EmployeeName = emp.FirstName + " " + emp.LastName;
14: empViewModel.Salary = emp.Salary.ToString("C");
15: if (emp.Salary > 15000)
16: {
17: empViewModel.SalaryColor = "yellow";
18: }
19: else
20: {
21: empViewModel.SalaryColor = "green";
22: }
23: empViewModels.Add(empViewModel);
24: }
25: employeeListViewModel.Employees = empViewModels;
26: employeeListViewModel.UserName = "Admin";
27: return View("MyView", employeeListViewModel);
28: }
29: </employeeviewmodel></employeeviewmodel></employee>
7. 執(zhí)行
關(guān)于實(shí)驗(yàn)7
是否可以制定強(qiáng)類型View列表?
是的 為什么要新建EmployeeListViewModel單獨(dú)的類而不直接使用強(qiáng)類型View的列表?1. 策劃未來會(huì)出現(xiàn)的呈現(xiàn)邏輯2. UserName屬性。UserName是與employees無關(guān)的屬性,與完整View相關(guān)的屬性。為什么刪除EmployeeViewModel 的UserName屬性,而不是將它作為EmployeeListViewModel的一部分?UserName 是相同的,不需要EmployeeViewModel中添加UserName。
結(jié)論
以上就是我們第二天所講的內(nèi)容,在第三天我們會(huì)學(xué)習(xí)新內(nèi)容
原文鏈接:http://www.codeproject.com/Articles/897559/Learn-MVC-in-days-Day
分享題目:七天學(xué)會(huì)ASP.NETMVC(二)——ASP.NETMVC數(shù)據(jù)傳遞
轉(zhuǎn)載來源:http://aaarwkj.com/article14/gppede.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、Google、App開發(fā)、定制開發(fā)、手機(jī)網(wǎng)站建設(shè)、App設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)