在上一節,咱們完成了一個項目搭建,咱們看到的是一個項目的分層架子,那接下來每一層作什麼以及須要引用哪些內容呢?在本節內容咱們還逐步拆分每一層的功能,順帶添加package包bootstrap
在這一層,主要是定義領域模型,咱們前面也說,Domain是不依賴任何層的,惟一可能存在的依賴也就是外部的幫助類庫了。因此這一層不須要咱們進行單獨處理引用關係的。瀏覽器
在這一層咱們主要定義一些實體和實體的行爲,爲了解決方案樹看着清爽一些,咱們分別添加幾個文件夾保存對應的內容app
基本這些就夠了。若是有須要咱們在單獨添加,其實T4那個文件夾如今加不加均可以。編輯器
在這一層,咱們進行數據持久化操做,咱們將使用Entity Framework 6+Sql Server這個組合來進行數據持久化,同時咱們要實如今Domain層定義的倉儲接口,還有就是在這一層還會使用Migration進行數據遷移,使用Fluent Api 來進行數據關係的配置,因此這一層的文件以下:性能
基本就這些文件夾。再看咱們在EF可能會用到的類庫,測試
就這個就能夠了,其餘的不是必須的,咱們用的時候再添加就能夠了。這裏注意,nuget安裝包EntityFramework有一個對應的EntityFramework.zh-Hans,一併安裝上吧,這樣在代碼編寫的時候就能夠看到繼承的中文提示了優化
最後,在EF層,咱們繼承了Domain 的倉儲接口,同時也會引用Domain的實體類,因此須要依賴Domain項目。右鍵添加項目引用便可插件
在這一層,咱們是爲了隔離UI層與EF層之間的關聯,數據模型流轉以下Entity→Dto→Model,其中Entity→Dto的轉換就是在這一層完成的。同時咱們還會把一些在頁面模型中沒有完成的模型組裝在這裏進行完。這一層文件夾以下:設計
其實,若是往三層上靠的話,應用層就有點相似原來的BLL層,幹些沒技術含量的活,可是咱們在這裏非要搞出來一個接口和一個實現的方式,這個並非爲了高大上,後續咱們會講到Ioc的時候會用到,同時咱們在Domain中引入了T4,這塊的不少代碼都是能夠生成的,因此不用糾結日誌
看一下須要引用的Nuget包:
最後來到UI層,用戶看到的那一坨屎同樣的東西都集中在這裏了。這一層要調用Application獲取數據,進行展現,把用戶提交的表單發送給Application而後到EF層進行持久化。
這一層文件夾在建立項目的時候已經基本都完備了,看一下這一層的引用,梳理一下咱們要用的技術
整理項目結構截圖以下:
全部準備工做基本完畢。下一步就能夠開始了。
比較糾結,我我的習慣是在整理需求的時候畫原型,而後設計數據模型,基本就是頁面設計→模型設計→邏輯處理→功能串聯→測試微調的開發思路。
可是由於這個是從項目中提出來的,需求已經弄完了並且不少代碼也完了,這個有點不知道從哪開始了。
整理整理思路在繼續,並且第一次想寫一個實戰的文章,才發現好難啊~