ASP.NET Web開(kāi)發(fā)框架之七 開(kāi)發(fā)流程與模式
經(jīng)過(guò)前面六篇文章的講解,基本的理論已經(jīng)介紹完畢,這一篇進(jìn)行實(shí)戰(zhàn)練習(xí),討論如何從頭開(kāi)始開(kāi)發(fā)一個(gè)完整的ASP.NET 頁(yè)面,并進(jìn)行數(shù)據(jù)讀寫(xiě),業(yè)務(wù)邏輯設(shè)定。
1 設(shè)計(jì)數(shù)據(jù)庫(kù)表 Table Design
公司表存放系統(tǒng)中的公司實(shí)例,表示進(jìn)行業(yè)務(wù)往來(lái)的實(shí)體,它的表結(jié)構(gòu)如下腳本所示
- CREATE TABLE [dbo].[Company](
- [CompID] [numeric](18, 0) IDENTITY(1,1) NOT NULL,
- [ParentCompID] [numeric](18, 0) NULL,
- [CompTypeID] [numeric](18, 0) NOT NULL,
- [CompNO] [varchar](20) NOT NULL,
- [CompName] [varchar](50) NOT NULL,
- [Corporation] [varchar](20) NULL,
- [CorpMobile] [varchar](20) NULL,
- [CorpTel] [varchar](20) NULL,
- [Address] [varchar](100) NULL,
- [Tel1] [varchar](20) NULL,
- [Tel2] [varchar](20) NULL,
- [Fax] [varchar](20) NULL,
- CONSTRAINT [PK_TCOMPANY] PRIMARY KEY CLUSTERED
- (
- [CompID] ASC
- )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
- ) ON [PRIMARY]
2 實(shí)體映射 ORM Mapping
打開(kāi)LLBL Gen,連接到數(shù)據(jù)庫(kù)并更新實(shí)體,把上面的Company表映射到實(shí)體CompanyEntity。設(shè)計(jì)字段名時(shí),最好以簡(jiǎn)明,可讀性好的詞命名,這樣可以增強(qiáng)映射到實(shí)體上的屬性的可讀性。
如果表與表之前有關(guān)聯(lián),LLBL Gen會(huì)自動(dòng)生成表之間的關(guān)聯(lián)。
3 數(shù)據(jù)讀寫(xiě)接口與實(shí)現(xiàn)的產(chǎn)生 Interface and Service Implementation
這一步驟也是自動(dòng)化的,不需要額外的腦力活動(dòng)。以Code Smith打開(kāi)模板Interface.cst和Manager.cst,選擇表對(duì)象為Company,生成代碼,把這此代碼拷貝到Visual Studio的項(xiàng)目中即可。
請(qǐng)?jiān)陧?xiàng)目的Source\Maintenance\Template路徑下獲取上面所提到的兩個(gè)模板,用以生成數(shù)據(jù)讀寫(xiě)接口與實(shí)現(xiàn)代碼。
4 ASP.NET 頁(yè)面布局與編程 ASP.NET Page Layout Design and Coding
向Web項(xiàng)目中添加一個(gè)ASP.NET 頁(yè)面,命名為company.aspx。我推薦以小寫(xiě)命名Web項(xiàng)目的文件夾,文件名和頁(yè)面類(lèi)型名稱(chēng)。為了讓它具備EntryPageBase的功能,我在頁(yè)面的首部,添加一個(gè)Toolbar,它用來(lái)承載工具箱中的系列工具,以進(jìn)行數(shù)據(jù)的前后瀏覽,增加刪除工作。其它的地方,以FormRow的方式安排布局。
FormRow會(huì)為它的Items平均分配寬度,所以每行FormRow最好放置相同的Items以讓界面布局看起來(lái)美觀整齊。
ASP.NET的后臺(tái)代碼看起來(lái)是這樣的,這里羅列所有的代碼,供您參考。
- [Function("AIITHD", "~/module/company.aspx")]
- public partial class company : EntryPageBase
- {
- protected override void PageLoadEvent(object sender, EventArgs e)
- {
- if (!IsPostBack)
- {
- TransactionType = EntityType.CompanyEntity;
- ddlCompanyGroup.InitializeValueListFromEnum(9);
- }
- base.PageLoadEvent(sender, e);
- }
- public override EntityBase2 LoadEntity(string refNo)
- {
- ICompanyManager manager = ClientProxyFactory.CreateProxyInstance<ICompanyManager>();
- CompanyEntity customer = manager.GetCompany(Convert.ToInt16(refNo));
- return customer;
- }
- public override void DeleteEntity(EntityBase2 entity)
- {
- CompanyEntity user = (CompanyEntity)entity;
- ICompanyManager manager = ClientProxyFactory.CreateProxyInstance<ICompanyManager>();
- manager.DeleteCompany(user);
- }
- public override void SaveEntity(EntityBase2 entity)
- {
- CompanyEntity user = (CompanyEntity)entity;
- ICompanyManager manager = ClientProxyFactory.CreateProxyInstance<ICompanyManager>();
- manager.SaveCompany(user);
- }
- }
首先給頁(yè)面分配一個(gè)功能編碼,比如此頁(yè)面的AIITHD,然后設(shè)定的Url屬性,這兩個(gè)同時(shí)附加到頁(yè)面的特性中去。
- [Function("AIITHD", "~/module/company.aspx")]
這里有些不足之處,到目前為止我還沒(méi)有找到根據(jù)ASP.NET頁(yè)面類(lèi)型,得到它的頁(yè)面文件。因?yàn)锳SP.NET的請(qǐng)求處理是以ASPX文件在瀏覽器中敲入后,發(fā)送到服務(wù)器來(lái)執(zhí)行的。所以,如果能找到這個(gè)辦法,則這里的Url設(shè)定可以省略。
其次,指定TransactionType = EntityType.CompanyEntity,這用來(lái)指定當(dāng)前頁(yè)面的實(shí)體為CompanyEntity,并對(duì)它進(jìn)行讀寫(xiě)操作,與頁(yè)面相關(guān)的數(shù)據(jù)綁定,回寫(xiě)到數(shù)據(jù)庫(kù)中,均需要此屬性。緊接著的是三個(gè)模板方法,LoadEntity用于加載公司實(shí)體,DeleteEntity用于刪除,SaveEntity用于保存修改后的實(shí)體。這三個(gè)方法均是override,它被頁(yè)面基類(lèi)調(diào)用。
最后執(zhí)行一下功能編碼為AIITHD的功能,來(lái)看看效果是怎樣的。在頁(yè)面的右上角輸入功能編碼,點(diǎn)擊Go按鈕。
關(guān)于數(shù)據(jù)綁定,所有的秘密藏在頁(yè)面文件中,我以Company No為例子,請(qǐng)看它的頁(yè)面文件
- <ext:TextBox ID="tbxName" runat="server" Label="Company No" DataBindingString="CompanyEntity:CompNo">
- </ext:TextBox>
它的DataBindingString屬性,在讀取數(shù)據(jù)時(shí),將實(shí)體屬性綁定到此控件,在保存時(shí),又讀取這個(gè)值,回寫(xiě)到實(shí)體中并保存到數(shù)據(jù)庫(kù)中,這樣可以減少大量重復(fù)的代碼。
原文鏈接:http://www.cnblogs.com/JamesLi2015/archive/2012/10/08/2714794.html
【編輯推薦】