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/,""))};
除了删除注释和不必要的空格之外,参数和变量名称被重命名(缩写)如下:
原始名称 | 重命名后 |
---|---|
imageTagAndImageID | t |
imageContext | a |
imageElement | r |
此示例来自于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 资源打包与压缩相关推荐
- [转帖]ASP.NET Core Web服务器 Kestrel和Http.sys 特性详解
ASP.NET Core Web服务器 Kestrel和Http.sys 特性详解 https://www.cnblogs.com/vipyoumay/p/7525478.html ASP.NET C ...
- 在 Azure 上部署 Asp.NET Core Web App
在云计算大行其道的时代,当你要部署一个网站时第一选择肯定是各式各样的云端服务.那么究竟使用什么样的云端服务才能够以最快捷的方式部署一个 ASP.NET Core的网站呢?Azure 的 Web App ...
- 如何测试ASP.NET Core Web API
在本文中,我们将研究如何测试你的ASP .NET Core 2.0 Web API解决方案.我们将了解使用单元测试进行内部测试,使用全新的ASP .NET Core的集成测试框架来进行外部测试. 本文 ...
- 重温.NET下Assembly的加载过程 ASP.NET Core Web API下事件驱动型架构的实现(三):基于RabbitMQ的事件总线...
重温.NET下Assembly的加载过程 最近在工作中牵涉到了.NET下的一个古老的问题:Assembly的加载过程.虽然网上有很多文章介绍这部分内容,很多文章也是很久以前就已经出现了,但阅读之后发现 ...
- 十分钟上线-基于函数计算开发 Restful web api asp.net core web app
前言 这篇文章适合所有的 C# 开发新手.老鸟以及想准备学习开发 C# 的程序猿..NET Core是一个开源通用的开发框架,支持跨平台, 阿里云函数计算推出了 dotnetcore2.1 runti ...
- ASP.NET Core Web API 与 SSL
SSL 一直没有真正研究过SSL,不知道下面的理解是否正确. SSL是Secure Sockets Layer的缩写,它用来保护服务器和客户端之前的通信.它是基于信任+加密的概念. 在介绍SSL的原理 ...
- 在 ASP.NET Core Web API中使用 Polly 构建弹性容错的微服务
在 ASP.NET Core Web API中使用 Polly 构建弹性容错的微服务 https://procodeguide.com/programming/polly-in-aspnet-core ...
- asp.net core web mvc之异常
与web api类似,asp.net core web mvc模板也是利用ExceptionHandler来处理错误,在starup的Configure配置数据发生时导向的/home/error pu ...
- ASP.NET Core学习资源汇总
ASP.NET Core入门学习资源汇总篇幅比較長,分为七个部分. (一)认识.NET Core (二)Vistual Studio安装.调试 (三)Asp.Net Core入门指南与学习路线 (四) ...
最新文章
- XMLHttpRequest cannot load解决方案
- 让Windows XP系统快上几倍的三个绝招
- struts2+hibernate+spring配置管理(一)-配置文件2
- Pytorch采坑记录:每隔num_workers个iteration数据加载速度很慢
- C语言课后习题(3)
- 【C++】 11_新型的类型转换
- Python数据分析与展示[第二周]
- mysql解压版有配置文件么_3分钟安装MySQL5.7解压版
- java stax_XML编程总结(五)——使用StAX接口操作xml
- 波形捕捉:(3)捕捉设备性能
- Git正解 脱水版 【7. Git命令】
- html上下表格合并单元格,html表格合并单元格的方法_WEB前端开发
- dns服务器一些网站无法解析,dns解析出错,导致有些网站解析出错,重启DNS服务器就正常了。 - Exchange论坛 - 51CTO技术论坛_中国领先的IT技术社区...
- win7计算机时间显示错误,Win7电脑时间同步出错怎么办?Win7电脑时间同步出错的解决方法...
- 小白入门isp数据流走向一
- 《痞子衡嵌入式半月刊》 第 31 期
- x^a=b(mod c)求解x在[0,c-1]上解的个数模板+原根求法
- OpenCV各个平台SDK下载
- Lasso 的 python实现
- Android内存优化之图片优化
热门文章
- IIS服务器上增加mp4格式MIME 类型映射设置具体步骤
- 二狗叫你制作千M网线的线序及方法
- Natasha 4.0 探索之路系列(三) 基本的动态编译
- 一款强大的Kubernetes API流量查看神器
- Natasha 4.0 探索之路系列(二) 「域」与插件
- 打独立运行包遇到无法trim咋解决
- 使用C#像google/zx一样编写脚本
- 当你的技术债务到期时,LinkedIn的故事 | IDCF
- WebSocket服务器(物联网下行通知神器)
- NET问答: 枚举 和 常量 在使用时该怎么抉择?