首先,咱們使用Visual Studio2019建立一個MVC架構的應用程序。步驟以下:
首先打開VS2019,在啓動頁選擇【建立新項目】。
而後選擇建立 ASP.NET Web 應用程序。
填寫項目名稱,點擊建立。
選擇MVC,去掉高級選項中的【爲HTTPS配置】,而後點擊建立。
這時咱們的MVC結構的項目就建立完成了,目錄結構以下:
css
下面咱們介紹下MVC的目錄結構。
1. Views(視圖)
存放與應用程序有關的 HTML 文件。
2. Controllers(控制器)
存放負責處理用戶輸入及響應的控制器類。
3. Models(模塊)
存放用來顯示到HTML中的程序模型類。
4. App_Start(入口處理程序)
包含應用程序的配置邏輯文件。
5. App_Data(應用程序存儲文件)
用來存儲應用程序數據。一般以文件形式包含數據存儲。
6. Content(存放靜態文件)
頁面顯示用到的靜態文件,例如樣式表css文件,圖標,圖片等內容。
7. Scripts(存放JavaScript文件)
存放js文件。
8. fonts(存放字體文件)
存放字體文件。
9. Global.asax(全局程序設置)
主要是web應用程序的全局設置文件。
10. packages.config(管理NuGet包)
用於跟蹤管理已安裝的軟件包及其各自的版本。
11. Web.config(網站配置)
存放一些應用程序用到的配置信息。html
global.asax這個文件包含全局應用程序事件的事件處理程序。web
好比,咱們能夠在這個文件中添加一個當應用程序遇到未處理的異常時的代碼。那麼當應用程序在運行過程當中遇到了異常,則會調用這段代碼。數據庫
再好比,咱們能夠添加一個當應用程序啓動時,適用於全局範圍的初始化代碼,例如路由規則,篩選規則,文件捆綁規則等,那麼這些規則在接下來全部的應用程序中都適用。咱們建立的MVC項目默認給咱們添加了這三個規則。如圖:
瀏覽器
能夠看到,MvcApplication類繼承自HttpApplication,HttpApplication是定義對 ASP.NET 應用程序內全部應用程序對象公用的方法、屬性和事件。因此global中能處理的事件不止我剛纔提到的兩種,更多詳細內容可查看個人ASP.NET MVC5基礎 – Global.asax詳解這篇文章。架構
如圖所示,Application_Start函數給全部應用程序註冊了路由,篩選,打包器三個規則,但這三個規則沒有直接寫在函數中,而是使用了App_Start文件下的配置類來管理。接下來咱們就來看App_Start這個文件夾的做用。mvc
App_Start文件夾存放的是應用程序啓動時全局配置的邏輯文件。app
MVC的核心就是Controller(控制器),它負責處理瀏覽器傳送過來的全部請求,並決定要將什麼內容響應給瀏覽器。Controller文件夾下儲存的就是各類控制器文件。框架
控制器自己只是一個類,該類有許多方法。在這些方法中,只要是公開方法,該方法就會被視爲是一種動做(Action)。只要有動做存在,就能夠經過該動做方法接收網頁請求並決定響應視圖。函數
同時,按照MVC的約定,控制器文件需符合如下規則:
1. Controller必須爲公開類;
2. Controller名稱必須以Controller結尾;
3. 必須繼承自MVC內建的Controller類;
4. 因此Action動做方法必須爲公開方法。
關於Controller的使用方法我會在後續文章中詳細說明。
Models文件夾下,儲存的是最終顯示到View頁面中的視圖模型。Model主要負責維持數據狀態,經過它將數據從數據庫中檢索出來傳遞給Controller處理,客戶端傳過來的數據也是經過Model傳回數據存儲系統中。
能夠說,Model(視圖模型)是View(視圖)鏈接數據庫的一個橋樑,它將呈如今用戶面前的內容轉換爲可存儲在數據庫中的內容,也是很是重要的。
View主要用於呈現數據。因爲Controller和相關的Service處理完業務邏輯並將結果打包成了Model實體,因此View只須要負責將Model實體轉換爲視圖呈現出來。更詳細的內容我會在後續文章中加以說明。
Web.config是一個配置文件,是基於XML的文本文件。
在發佈Web應用程序時,Web.config文件並不編譯進dll文件中,它主要存儲一些ASP.NET應用程序的配置信息,好比上傳文件的保存路徑可配置在appSettings節點;數據庫鏈接字符可保存在connectionStrings節點;用於定義自定義錯誤信息的customErrors節點等等…
經過本文能夠了解到,如何建立第一個MVC項目、MVC框架的目錄結構以及MVC下主要文件的做用。
更多內容可訪問個人我的博客:http://www.yunc.top/