在本文章中,我們将探索并了解 http://asp.net core 項目檔案。 我們使用 C#作為程式設計語言,是以項目檔案具有.csproj 擴充名。
如果您使用過以前版本的 http://ASP.NET,那麼您可能對此檔案非常熟悉,但此檔案中包含的格式和内容在 asp.ne Core 中發生了很大變化。
一個重要的變化是,項目檔案不包含任何檔案夾或檔案引用。
簡單解釋後的意思就是。在以前的 http://ASP.NET 中,當我們使用
解決方案資料總管向項目添加檔案或檔案夾時,
項目檔案中會包含對該檔案或檔案夾的引用。但是在 http://ASP.NET Core 中,
項目檔案不包含任何檔案夾或檔案引用。 由檔案系統來确定哪些檔案和檔案夾屬于項目。在項目的根目錄中存在的所有檔案和檔案夾都是屬于項目的一部分,将顯示在解決方案資料總管中。 當您在添加檔案或檔案夾時,該檔案或檔案夾将會變成項目的一部分,會立即顯示在解決方案資料總管中。 同樣,當您在解決方案下的任何檔案夾中删除檔案或檔案夾時,該已删除的檔案或檔案夾不再是項目的一部分,會立即從解決方案資料總管中不再顯示出來。
另外我們與
項目檔案的工作方式也發生了變化。在以前版本的 http://asp.net 中,為了能夠編輯項目檔案,我們首先要解除安裝項目,編輯并儲存項目檔案,然後重新附加元件目。而在 http://asp.net core 中,我們可以編輯項目檔案而無需解除安裝項目。
在解決方案中,右鍵單擊項目名稱并選擇“編輯 StudentManagement.csproj” 檔案。
這将在編輯器中打開.csproj 檔案。
<Project Sdk="Microsoft.NET.Sdk.Web">
<PropertyGroup>
<TargetFramework>netcoreapp2.2</TargetFramework>
<AspNetCoreHostingModel>InProcess</AspNetCoreHostingModel>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="Microsoft.AspNetCore.App" />
<PackageReference Include="Microsoft.AspNetCore.Razor.Design" Version="2.2.0" PrivateAssets="All" />
</ItemGroup>
</Project>
C#
TargetFramework:顧名思義,此元素是用于指定應用程式的目标架構,即您希望為應用程式提供的 APId 程式集。為了指定目标架構,我們使用了一個名為 Target Framework Moniker(TFM)的東西。正如您在上面的示例中所看到的,我們的應用程式針對 TargetFramework 的值為 netcoreapp2.2。netcoreapp2.2 是.NET Core 2.2 的 Moniker。當我們建立此應用程式時,我們從
建立項目中下拉清單中選擇了**.NET Core 2.2**作為目标架構。
AspNetCoreHostingModel:此元素指定應如何托管 http://Asp.Net Core 應用程式。它表示程式應該托管 InProcess(程序内)還是 OutOfProcess(程序外)。 InProcess 的值指定我們想要使用程序内托管模型,即在 IIS 工作程序(w3wp.exe)中托管我們的 http://asp.net core 應用程式。 OutOfProcess 的值指定我們要使用程序外托管模型,将 Web 請求轉發到運作 Kestrel 伺服器的後端 http://ASP.NET Core 應用程式。
我們将在即将釋出的視訊中詳細讨論 InProcess(程序内)和 OutOfProcess(程序外)托管。PackageReference
:顧名思義,此元素用于包含對為您的應用程式安裝的所有 NuGet 包的引用。在項目檔案中,我們有以下 2 個 NuGet 包。
Microsoft.AspNetCore.App
Microsoft.AspNetCore.Razor.Design
Microsoft.AspNetCore.App :此 NuGet 包稱為
metapackage。 metapackage 本身是沒有任何的内容的,它隻是包含了其他包的依賴資訊。 您可以在
解決方案資料總管中的 NuGet 下找到此中繼資料包,而 NuGet 又位于**依賴項(Dependencies)**下。展開中繼資料包時,您可以找到所有依賴項。
Microsoft.AspNetCore.App裡面包含了
http://ASP.NET Core 2.2及更高版本和
Entity Framework Core 2.2及更高版本的所有元件。
在 http://ASP.NET Core 2.1 及更高版本的預設項目模闆,都是會使用這個包。
請注意,metapackage 中沒有版本号。 未指定版本時,SDK 會指定隐式版本。 .NET Core 團隊建議依賴 SDK 指定的隐式版本,而不是在包引用上顯式設定版本号。 如果目前還不完全清楚,請不要擔心。
Microsoft.AspNetCore.Razor.Design:此軟體包包含對 Razor 的 MSBuild 支援,并由 Microsoft.AspNetCore.App 的 metapackage 包引用。
歡迎添加個人微信号:Like若所思。
歡迎關注我的公衆号,不僅為你推薦最新的博文,還有更多驚喜和資源在等着你!一起學習共同進步!