日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

ASP.NET Core Web 资源打包与压缩

發布時間:2023/12/4 asp.net 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ASP.NET Core Web 资源打包与压缩 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本文將介紹使用的打包和壓縮的優點,以及如何在ASP.NET Core應用程序中使用這些功能。

概述

在ASP.Net中可以使用打包與壓縮這兩種技術來提高Web應用程序頁面加載的性能。通過減少從服務器請求的次數和減少資源文件的體積來提高加載性能。

  • 打包是一地將多個文件(CSS,JavaScript等資源文件)合并或打包到單個文件。文件合并可減少了 Web 資源文件從服務器的所需請求數,這樣也可提高頁面載入的性能。

  • 壓縮是將各種不同的代碼進行優化,以減少請求資源文件的體積。壓縮的常見方法刪除不必要的空格和注釋,并將變量名縮減為一個字符。

例如下面JavaScript函數:

AddAltToImg = function (imageTagAndImageID, imageContext) {///<signature>///<summary> Adds an alt tab to the image// </summary>//<param name="imgElement" type="String">The image selector.</param>//<param name="ContextForImage" type="String">The image context.</param>///</signature>var imageElement = $(imageTagAndImageID, imageContext);imageElement.attr('alt', imageElement.attr('id').replace(/ID/, ''));}

壓縮后,函數簡化為如下:

AddAltToImg=function(t,a){var r=$(t,a);r.attr("alt",r.attr("id").replace(/ID/,""))};

除了刪除注釋和不必要的空格之外,參數和變量名稱被重命名(縮寫)如下:

原始名稱重命名后
imageTagAndImageIDt
imageContexta
imageElementr

此示例來自于github:https://github.com/aspnet/Docs/blob/master/aspnetcore/client-side/bundling-and-minification.md

bundleconfig.json文件

MVC項目模板提供了一個bundleconfig.json配置文件,它定義了打包的配置選項。默認情況下,實現了自定義腳本文件(wwwroot/js/site.js) 和樣式表 (wwwroot/css/site.css) 文件的配置。

[ ?{"outputFileName": "wwwroot/css/site.min.css","inputFiles": [ ? ? ?"wwwroot/css/site.css"] ?},{"outputFileName": "wwwroot/js/site.min.js","inputFiles": [ ? ? ?"wwwroot/js/site.js"],"minify": {"enabled": true,"renameLocals": true},"sourceMap": false}]

配置選項詳細說明:

  • outputFileName - 要輸出打包包文件的路徑。 與bundleconfig.json?文件的相對路徑。?必填

  • inputFiles - 要打包的的文件路徑數組。 與是配置文件的相對路徑。?選填,如果是空數組會輸出一個空文件。 支持通配符模式。

  • minify - 輸入出類型的壓縮選項。?選填,默認值 -minify: { enabled: true }

  • 輸入出文件類型可用配置選項。

    • CSS Minifier

    • JavaScript Minifier

    • HTML Minifier

  • includeInProject - 將生成的文件添加到項目。?選填,?默認值 - false

  • sourceMaps - 生成合并文件的源文件映射。?選填,默認值 - false

在項目中使用打包和壓縮

在VS 2015/2017需要安裝BundlerMinifierVsix,安裝完成后需要重啟VS。

在bundleconfig.json文件右鍵單擊,然后選擇任務運行程序資源管理器。



在Update all fiels選項右鍵單擊,然后選擇Run。



在項目中會分別生成壓縮后的資源文件。



在視圖中使用打包壓縮后的資源文件

在上一篇博客《ASP.NET Core配置環境變量和啟動設置》我們已經討論過環境變量,在視圖中通過 Environment 標簽,分別定義開發、預演和生產環境加載對應的資源文件。

<environment names="Development"><link rel="stylesheet" href="~/css/site.css" /><script src="~/js/site.js" asp-append-version="true"></script></environment><environment names="Staging,Production"><link rel="stylesheet" href="~/css/site.min.css" asp-append-version="true" /><script src="~/js/site.min.js" asp-append-version="true"></script></environment>

當在開發模式下運行應用程序,我們使用未壓縮Css和腳本文件;在生產環境中,我們壓縮后的資源文件,這樣可以提高應用程序的性能。

總結

在ASP.Net中可以使用打包與壓縮這兩種技術來提高Web應用程序頁面加載的性能。希望上面的內容對大家的學習有所幫助,謝謝!

感謝無語1994提供的另一個解決方案,通過安裝BundlerMinifier Nuget包,也可以達到合并與壓縮的目的。原文地址:《10,關于在vs2017中的netcore項目使用BundlerMinifier 配置問題》。

參考:

  • https://github.com/aspnet/Docs/blob/master/aspnetcore/client-side/bundling-and-minification.md

  • https://www.codeproject.com/Articles/1158377/NET-Core-Startup

第一次使用Markdown寫博客,還不是很習慣,排版不夠整齊,請大家見諒,謝謝

原文地址:http://www.cnblogs.com/tdfblog/p/bundling-and-minification-in-asp-net-core.html


.NET社區新聞,深度好文,微信中搜索dotNET跨平臺或掃描二維碼關注

創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的ASP.NET Core Web 资源打包与压缩的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。