av激情亚洲男人的天堂国语,日韩欧美精品一中文字幕,无码av一区二区三区无码,国产又色又爽又刺激的a片,国产又色又爽又刺激的a片

Web應用架構分析之查詢傳遞

在Web應用開發(fā)中,最常見也容易變化的一種需求是根據不同的查詢條件獲取數據列表。如何傳遞查詢條件將影響程序應對需求變化的能力,一定要在架構中重點考慮。

光澤ssl適用于網站、小程序/APP、API接口等需要進行數據傳輸應用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯系或者加微信:18982081108(備注:SSL證書合作)期待與您的合作!

開始時我們使用一堆參數傳遞查詢條件,比如:

 
 
 
  1. List GetMsgList(int pageIndex, int pageSize, int RecipientId); 

結果,每個不同的查詢都要寫一個接口,產生了一堆接口;查詢條件改變,接口也隨之要改。寫程序最痛苦的事莫過于接口的頻繁變化。

后來使用查詢對像,比如:

 
 
 
  1. List GetMsgList(SiteMsgQuery msgQuery); 

這樣,查詢條件改變時,只需修改SiteMsgQuery的定義,接口保持不變。采用這個方法后,寫代碼比之前少了很多痛苦。

但使用這個方法有個地方不爽,完成一次查詢需要進行兩次實例化,一次是查詢對象SiteMsgQuery的實例化,一次是領域對象SiteMsgManager(負責業(yè)務邏輯)的實例化。在博客園程序架構中,查詢對象的實例化是在表現層完成的,如果是ajax調用,json會自動反序列為查詢對象;領域對象的實例化在服務層完成。

為了讓代碼寫的更爽一些,我們又進行了嘗試,取消查詢對象SiteMsgQuery,將它的屬性放到領域對象中。這樣減少了一次實例化,只需一次,如果是ajax調用,可以實現服務器端“零實例化”。

下面看一下代碼示例:

領域模型的定義:

 
 
 
  1. [DataContract]  
  2. public class SiteMsgManager  
  3. {  
  4. public SiteMsgManager()  
  5. {  
  6. }  
  7.  
  8. #region Properies  
  9.  
  10. [DataMember]  
  11. public int PageIndex { get; set; }  
  12.  
  13. [DataMember]  
  14. public int PageSize { get; set; }  
  15.  
  16. [DataMember]  
  17. public int RecipientId { get; set; }  
  18.  
  19. public List List { get; set; }  
  20.  
  21. #endregion  
  22.  
  23. public void GetList()  
  24. {  
  25.     using (SpaceObjectContext context = new SpaceObjectContext())  
  26.     {  
  27.         this.List = context.SiteMsgs  
  28.             .Where(msg => msg.RecipientSpaceUserId == this.RecipientId)  
  29.             .OrderByDescending(msg => msg.id)  
  30.             .Skip((PageIndex - 1) * PageSize)  
  31.             .Take(this.PageSize)  
  32.             .ToList();  
  33.     }             

服務實現類(也是WCF的服務實現):

 
 
 
  1. public class MsgService : IMsgService  
  2. {  
  3.     public List GetMsgList(SiteMsgManager siteMsgManager)  
  4.     {  
  5.         siteMsgManager.GetList();  
  6.         return siteMsgManager.List;  
  7.     }  

UI層調用代碼(WCF調用,ASP.NET MVC控制器):

 
 
 
  1. public class MsgController : Controller  
  2. {  
  3.     //ajax調用  
  4.     [HttpPost]      
  5.     public ActionResult List(SiteMsgManager msgManager)  
  6.     {  
  7.         return View("MsgList", GetInboxMsgList(msgManager));  
  8.     }  
  9.  
  10.     public ActionResult Inbox()  
  11.     {  
  12.         SiteMsgManager msgManager = new SiteMsgManager()  
  13.         {  
  14.             PageIndex = 1,  
  15.             PageSize = 30 
  16.         };          
  17.         return View("Inbox", GetInboxMsgList(msgManager));  
  18.     }  
  19.  
  20.     private List GetInboxMsgList(SiteMsgManager msgManager)  
  21.     {  
  22.         int spaceUserId = Util.GetCurrentUser
    (System.Web.HttpContext.Current).SpaceUserID;  
  23.         msgManager.RecipientId = spaceUserId;  
  24.         MsgServiceClient client = new MsgServiceClient();  
  25.         List siteMsgList = client.GetMsgList(msgManager).ToList();  
  26.         try { client.Close(); }  
  27.         catch { client.Abort(); }  
  28.         return siteMsgList;  
  29.     }  

看看上面供ajax調用的List方法,不需要進行SiteMsgManager的實例化,系統(tǒng)根據ajax客戶端傳遞過來的json參數自動反序列化生成SiteMsgManager對象。

再來看看ajax客戶端代碼:

 
 
 
  1. function GetMsgList(pageIndex, pageSize) {  
  2.     var msgManager = {}  
  3.     msgManager.PageIndex = pageIndex;  
  4.     msgManager.PageSize = pageSize;  
  5.  
  6.     $.ajaxSettings.dataType = 'plain/text';     
  7.     $.ajaxSettings.url = '/msg/list';  
  8.     $.ajaxSettings.data = '{"msgManager":' + JSON.stringify(msgManager) + '}';  
  9.     $.ajaxSettings.success = function (data) {  
  10.         $("#msg_list").html(data);  
  11.     };  
  12.     $.ajax();  

js傳遞的也是一個對像。

整個ajax調用的流程是這樣的:js對象(msgManager)->json->MsgController(MVC控制器)->代理領域對象SiteMsgManager(WCF客戶端代理類的實例)->WCF服務接口->WCF服務實現(自動通過反序列化生成領域對象SiteMsgManager,并調用GetList()方法)->領域對象完成業(yè)務邏輯操作返回數據。

采用這種方法,感覺寫代碼比以前更享受了。我們在實際開發(fā)中也開始使用這種架構,并根據實際使用情況進一步改進。
 

【編輯推薦】

  1. Web開發(fā)者欣喜若狂的40個UI設計工具和資源
  2. 是什么讓一個Web應用程序變得如此偉大?
  3. Web打印的在線設計
  4. 2011年Web前端技術展望:jQuery移動開發(fā)新選擇
  5. 代替桌面工具 10款最給力的Web開發(fā)與設計工具

名稱欄目:Web應用架構分析之查詢傳遞
本文路徑:http://uogjgqi.cn/article/djohgic.html
掃二維碼與項目經理溝通

我們在微信上24小時期待你的聲音

解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯網交流