預編譯是ASP .Net Core的預設方式。在發佈時,預設會將系統中的所有Razor視圖進行預編譯。編譯好的視圖DLL統一命名為 xxx.PrecompiledViews.dll 或者 xxx.Views.dll ...
預編譯
預編譯是ASP .Net Core的預設方式。在發佈時,預設會將系統中的所有Razor視圖進行預編譯。編譯好的視圖DLL統一命名為 xxx.PrecompiledViews.dll
或者 xxx.Views.dll
動態編譯
將項目整個配置成動態編譯很簡單,添加一個配置項目MvcRazorCompileOnPublish
,值為false
即可
<PropertyGroup> <MvcRazorCompileOnPublish>false</MvcRazorCompileOnPublish> </PropertyGroup>
這樣在發佈的時候,所有的Razor視圖都不會被預編譯了,並且所有的視圖都會一同被髮布。
註意:在ASP .Net 2.2以後,僅在開發環境下,修改視圖可時時生效。發佈以後產線環境修改視圖是不會立即生效的,要重啟程式才會生效。詳細可參閱:https://docs.microsoft.com/en-us/aspnet/core/mvc/views/view-compilation?view=aspnetcore-2.2
如果希望在產線環境也可以修改視圖時時生效,需要主動設置RazorViewEngineOptions.AllowRecompilingViewsOnFileChange
的值為true
public class RazorViewEngineOptionsSetup : ConfigureOptions<RazorViewEngineOptions> { public RazorViewEngineOptionsSetup(IHostingEnvironment hostingEnvironment, IPluginLoader loader) : base(options => { options.AllowRecompilingViewsOnFileChange = true; }) { } }
然後添加到容器中:
services.TryAddEnumerable(ServiceDescriptor.Singleton<IConfigureOptions<RazorViewEngineOptions>, RazorViewEngineOptionsSetup>());
混合編譯
預編譯和動態編譯都有各自的優點,你可以選擇將它們混合起來使用。例如如果你希望在發佈時只預編譯部分視圖,而部分視圖要採用動態編譯的模式,可以在項目文件上配置排除不需要預編譯的視圖。例如將Views目錄下的全部進行預編譯,而主題目錄和郵件模板目錄下的視圖不需要預編譯:
<ItemGroup> <MvcRazorFilesToCompile Include="Views\**\*.cshtml" Exclude="wwwroot\themes\**\*.cshtml;EmailTemplates\**\*.cshtml" /> </ItemGroup>
進階
關於更多Razor的配置,可以參閱微軟的官方說明文檔:https://docs.microsoft.com/en-us/aspnet/core/razor-pages/sdk?view=aspnetcore-2.2
原文地址:http://www.zkea.net/codesnippet/detail/razor-compilation.html