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

淺談ASP.NET MVC 3中如何使用Model

開發 后端
今天我們將要談到的是ASP.NET MVC 3中如何使用Model,用于遠程驗證等功能上。歡迎大家加入討論。

昨天博客發了新文章,講一下我對如何使用MVC中的Model的看法,不是什么大技術,當是一個技術討論^^

原文地址:http://www.youguanbumen.net/Article.aspx?id=79

原文:

前兩天寫了個文章ASP.NET MVC 3 —— Model遠程驗證,主要記錄了一下ASP.NET MVC 3中新增的RemoteAttribute類的使用,得益于這個類,我們可以在模型中為屬性配置客戶端遠程校驗的業務,文章中給了出一個簡單的實體類MyUser_Add,舉了一個最常見的注冊用戶時驗證用戶名是否存在的例子,最后成功地對用戶名實現了用ajax加薪校驗的功能。給出Model的代碼如下:

  1. /// <summary>  
  2. /// 用戶添加操作的模型  
  3. /// </summary>  
  4. publicclassMyUser_AddModel  
  5. {  
  6.     #region MyRegion  
  7.     /// <summary>  
  8.     /// 用戶名  
  9.     /// </summary>  
  10.     [DisplayName("登錄賬號")]  
  11.     [Required(ErrorMessage = "用戶賬號不能為空")]  
  12.     [Remote("CheckUserAccountExists""Test", ErrorMessage = "用戶賬號已存在")] 
  13. // 遠程驗證(Ajax)  
  14.     publicstringUserAccount { getset; }  
  15. }   
  16.  
  17.       
  18.  

文章發到博客園上面之后有朋友提出一了一點:“這個我們可以認為在創建的時候解決重復問題,但是如果是Update的話,我相信這樣的語句應該也會報錯誤的”。就是說如果這個Model用于做Update操作的時候,校驗用戶名是否存在的方法和Add操作會有點不同,因為要把自己排除在外,例如原來的用戶名叫”user1“修改后還叫”user1“,這時候判斷用戶名是否存在的標準是”如果存在用戶名是‘user1’的并且用戶ID號不是當前這個要修改的用戶,那么用戶不可用(存在)“,而Add操作的時候不存在”自己“,所以我看可以理解為兩個操作都需要判斷用戶名是否存在,但是使用了不同的策略!

剛好之前看了ASP.NET MVC 3自帶的Demo(就是創建MVC3.0項目后生成的那個- -!),想寫一下我自己認為的”微軟希望我們怎么去設計MVC中的Model”的看法,發現似乎和這個問題有點聯系,以下是我個人的觀點:

首先我們看下Demo項目中Models目錄下的AccountModels.cs,下面的代碼摘自這個文件中的兩個我認為很有代表性的類,都是和用戶有關的,源代碼如下:

  1. publicclassLogOnModel  
  2. {  
  3.     [Required]  
  4.     [Display(Name = "User name")]  
  5.     publicstringUserName { getset; }  
  6.     [Required]  
  7.     [DataType(DataType.Password)]  
  8.     [Display(Name = "Password")]  
  9.     publicstringPassword { getset; }  
  10.     [Display(Name = "Remember me?")]  
  11.     publicboolRememberMe { getset; }  
  12. }  
  13. publicclassRegisterModel  
  14. {  
  15.     [Required]  
  16.     [Display(Name = "User name")]  
  17.     publicstringUserName { getset; }  
  18.     [Required]  
  19.     [DataType(DataType.EmailAddress)]  
  20.     [Display(Name = "Email address")]  
  21.     publicstringEmail { getset; }  
  22.     [Required]  
  23.     [ValidatePasswordLength]  
  24.     [DataType(DataType.Password)]  
  25.     [Display(Name = "Password")]  
  26.     publicstringPassword { getset; }  
  27.     [DataType(DataType.Password)]  
  28.     [Display(Name = "Confirm password")]  
  29.     [Compare("Password", ErrorMessage = "The password and confirmation password do not match.")]  
  30.     publicstringConfirmPassword { getset; }  
  31. }  

注意上面兩個類的類名,我們很容易讀懂一個是“(用戶)登錄模型”,一個是“(用戶)注冊模型”,有意思的地方在于兩個類都用UserName、Password兩個屬性,UserName的驗證方式完全一樣,而Password有所不同,RegisterModel中多了一個ValidatePasswordLengthAttribute的特性——一個自定義驗證特性。這兩個模型對應的是不同的Action-View,于是我的理解是:Model是為了Actioin-View而存在的。例如,有一個頁面是用來顯示一張表單,這張表單會被提交到一個介紹Post請求的Action中,這時候就會創建一個和這個表單對應的Model,用來在View和Action中充當媒介的作用(所謂的“實體傳參”)。

回到上面那個檢測用戶名是否存在的問題,基于這個想法可以得出一個解決方案,那就是創建另外一個新類,叫做MyUser_UpdateModel(用戶修改模型),可以得出以下的代碼

  1. publicclassMyUser_UpdateModel  
  2. {  
  3.     /// <summary>  
  4.     /// 用戶名  
  5.     /// </summary>  
  6.     [DisplayName("登錄賬號")]  
  7.     [Required(ErrorMessage = "用戶賬號不能為空")]  
  8.     [ValidateUserAccountAttribute] // 自定義驗證  
  9.     [Remote("CheckUserAccountExistsForUpdate""Test", ErrorMessage = "用戶賬號已存在")] // 遠程驗證(Ajax)  
  10.     publicstringUserAccount { getset; }  
  11. }  

注意到遠程驗證調用的是另外一個Action,這個Action的代碼如下:

  1.  /// <summary>  
  2. /// 用于驗證用戶賬號是否存在的Action(Update操作時使用)  
  3. /// </summary>  
  4. /// <param name="UserAccount">用戶賬號</param>  
  5. /// <returns></returns>  
  6. [HttpGet]  
  7. public ActionResult CheckUserAccountExistsForUpdate(string UserAccount)  
  8. {  
  9.     var ms = ModelState;  
  10.     string[] existsUsers = { "wodanwojun" };  
  11.     bool exists = string.IsNullOrEmpty(existsUsers.FirstOrDefault(u => u.ToLower() == UserAccount.ToLower())) == false;  
  12.     return Json(!exists, JsonRequestBehavior.AllowGet);  
  13. }   
  14.  
  15.  
  16.    
  17.  
  18.     public class MyUser_UpdateModel  
  19.     {  
  20.         /// <summary>  
  21.         /// 用戶名  
  22.         /// </summary>  
  23.         [DisplayName("登錄賬號")]  
  24.         [Required(ErrorMessage = "用戶賬號不能為空")]  
  25.         [ValidateUserAccountAttribute] // 自定義驗證  
  26.         [Remote("CheckUserAccountExistsForUpdate""Test", ErrorMessage = "用戶賬號已存在")] // 遠程驗證(Ajax)  
  27.         public string UserAccount { getset; }  
  28.     } 

這里假設要修改的用戶的用戶名叫做“youguanbumen”,所以驗證的時候如果輸入了有關部門是不應該提示“該賬號已存在”的(因為就是他自己,用了這個賬號是沒問題的)。控制器的代碼我就不寫咯,大致就是得到一個用戶名叫做“youguanbumen”的Model——MyUser_UpdateModel類,然后通過return View(object model)方法丟給View(當然,View是強類型的——MyUser_UpdateModel類),測試結果截圖如下:

1、輸入“wodanwojun”作為用戶名,發現通不過,就像下面這張截圖這樣,原因請見上面的代碼!

2、輸入“youguanbumen”作為用戶名。發現沒有錯誤提示,就像下面這張截圖這樣,原因請見上面的代碼,并對照前一篇文章中另外一個用于遠程校驗的Action的代碼!

總結一下:似乎寫出來的每一篇文章都不短但是講的東西都很少,呵呵,請別介意^_^。雖然寫代碼的經驗很不多,但是個人對于代碼還是有一些自己的看法的。選擇一個框架來開發一個系統,就意味著在開發的過程中你需要遵循某些約定好的東西,例如選擇WebForm來開發系統,就盡量的接受”事件相應“和服務器端控件;選擇了MVC就要接受把C#代碼嵌到頁面去的這個事實,當然如果使用了某些RIA框架后可能不出現這種情況(因為頁面上的東西基本都是異步請求回來的)。特別是多人開發的時候,我們有必要遵循某些套路來寫代碼,例如上面這個例子,也許寫Model、寫View和寫Action是三個不同的人來完成的時候,“如果遵循這一個Action會有一個Model來支持它”的這種套路來走的話,每個人都很容易找到代碼的下手點,寫View的人知道如何去聲明頁面為強類型(他會去找相關的Model),寫Action的人知道return View(object model)中的model是啥,也知道用于處理Post的Action的參數是什么,寫Model的人需要很了解業務,知道哪些字段是必填的,那些字段有長度限制等等,但是他也許不知道這個Model會被拿去怎么展示!

ASP.NET MVC中的Model是和業務緊密相關的,有什么樣的業務需求就會產生什么樣的Model,并且會有相應的Action來出來它,有相應的View來展示它。如果基于這個想法來開發系統的話,很有可能得出這樣一個簡要的開發流程:研究業務-->轉化為對應的Model,根據業務需求對Model的屬性配置驗證特性-->設計數據庫表來對數據進行存放(也許是xml也不一定)-->設計View來展示它,設計Action來處理它......。

原文鏈接:http://www.cnblogs.com/serafin/archive/2011/01/27/1945934.html

 

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

2009-07-23 15:44:39

ASP.NET MVC

2009-07-22 13:24:24

ASP.NET MVC

2010-04-09 09:28:37

View Model

2009-12-21 10:05:10

ASP.NET MVC

2009-12-07 09:23:05

ASP.NET MVC

2009-06-15 10:57:51

FluentHtmlASP.NET MVC

2009-01-16 13:17:16

AjaxASP.NET.NET

2009-07-20 12:42:04

MvcContrib.ASP.NET MVC

2009-07-27 13:01:28

TreeViewASP.NET

2011-06-08 11:36:16

ASP.NETrender

2011-04-14 09:19:22

ASP.NET MVC

2009-10-29 09:15:32

ASP.NET MVCDropDownLis

2009-07-20 15:30:11

ASP.NET應用

2009-07-22 16:11:43

ASP.NET AJA

2009-07-24 13:20:44

MVC框架ASP.NET

2010-10-20 09:05:16

ASP.NET MVC

2010-12-07 09:38:15

ASP.NET MVC

2009-07-24 10:52:42

ASP.NET ISA

2009-07-31 12:43:59

ASP.NET MVC

2009-03-06 10:28:30

MVCASP.NET異步Action
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美中文字幕在线观看 | 男人天堂网av| 色婷婷在线视频 | 亚洲欧美在线视频 | 欧洲毛片| 中文字幕乱码一区二区三区 | 国产高清一区二区三区 | 欧美精品免费观看二区 | 国产一区二区三区网站 | 亚洲精品中文字幕在线观看 | 久久久成人网 | 久久日韩粉嫩一区二区三区 | 中文字幕二区 | 日本在线精品视频 | 精品1区2区3区 | 欧美成人影院 | 成人免费观看男女羞羞视频 | 欧美日韩中文在线 | 欧美在线视频一区二区 | 欧洲免费毛片 | 一区免费视频 | 91天堂 | 国产资源在线观看 | 国产一区二区在线视频 | 久热久热| 综合久久综合久久 | 一本一道久久a久久精品综合 | 91极品尤物在线播放国产 | 欧美视频一区二区三区 | 久久精品久久久 | 成人国产精品免费观看 | 成人精品国产一区二区4080 | 欧美日韩在线免费 | 久久中文网 | av在线天堂| 日本成年免费网站 | 日本中文字幕在线观看 | 亚洲成人播放器 | 超碰在线播 | 精品一区二区在线视频 | 这里只有精品999 |