js css优化-- 合并和压缩
在项目框架中,首先要引用很多css和js文件,80%的用户响应时间都是浪费在前端。而这些时间主要又是因为下载图片、样式表、JavaScript脚本、flash等文件造成的。减少这些资源文件的Request请求数将是提高网页显示效率的重点。
这里好像有个矛盾,就是如果我减少了很多的图片,样式,脚本或者flash,那么网页岂不是光秃秃的,那多难看呢?其实这是一个误解。我们只是说尽量的减少,并没有说完全不能使用。减少这些文件的Request请求数,我们这里主要针对js和css文件进行优化,使用Combres工具
第一步准备工具Nuget可以百度,也可以在此http://nuget.org/
第二步通过VS2010管理NuGet程序包来查找第二个工具,也就是本次要使用的工具Combres的工具。
点击安装后,会在项目中生成一系列的文件和引用。
在App_Data/combres.xml,这个就是设置压缩/合并的文件配置。
第三步进行对配置文件进行处理,当然主要是对css文件和Js文件进行相关配置,修改combres.xml如下。
<?xml version= "1.0" encoding= "utf-8" ?> <!-- This file contains basic settings needed for most web apps. For full Combres settings (with explanation), refer to the sample definition file: combres_full_with_annotation.xml Also, refer to Combres' documentation: http: //combres.codeplex.com/documentation --> <combres xmlns= 'urn:combres' > <filters> <filter type= "Combres.Filters.FixUrlsInCssFilter, Combres" /> </filters> <cssMinifiers> <minifier name= "yui" type= "Combres.Minifiers.YuiCssMinifier, Combres" > <param name= "CssCompressionType" type= "string" value= "StockYuiCompressor" /> <param name= "ColumnWidth" type= "int" value= "-1" /> </minifier> </cssMinifiers> <jsMinifiers> <minifier name= "msajax" type= "Combres.Minifiers.MSAjaxJSMinifier, Combres" binderType= "Combres.Binders.SimpleObjectBinder, Combres" > <param name= "CollapseToLiteral" type= "bool" value= "true" /> <param name= "EvalsAreSafe" type= "bool" value= "true" /> <param name= "MacSafariQuirks" type= "bool" value= "true" /> <param name= "CatchAsLocal" type= "bool" value= "true" /> <param name= "LocalRenaming" type= "string" value= "CrunchAll" /> <param name= "OutputMode" type= "string" value= "SingleLine" /> <param name= "RemoveUnneededCode" type= "bool" value= "true" /> <param name= "StripDebugStatements" type= "bool" value= "true" /> </minifier> </jsMinifiers> <!--defaultDuration 默认缓存的时间,单位为天数--> <!--defaultVersion 合并后的资源版本,在你修改了资源文件后需要对版本进行修改,你可以指定auto或者手动设置一个版本号--> <!--defaultDebugEnabled 调试的模式,为 true 时那么资源文件不进行压缩,开发时可以设置成 true ,上线后设置成 false --> <resourceSets url= "~/combres.axd" defaultDuration= "30" defaultVersion= "auto" defaultDebugEnabled= "false" defaultIgnorePipelineWhenDebug= "true" localChangeMonitorInterval= "30" remoteChangeMonitorInterval= "60" > <resourceSet name= "siteCss" type= "css" minifierRef= "yui" > <span style= "background-color: #99cc00;" > <resource path= "~/Content/Site.css" /> <resource path= "~/Content/StyleSheet1.css" /> </resourceSet> <resourceSet name= "siteJs" type= "js" > <resource path= "~/Scripts/jquery-1.5.1.min.js" minifierRef= "msajax" /> <resource path= "~/Scripts/test.js" minifierRef= "off" /></span> </resourceSet> </resourceSets> </combres> |
这是我修改之后的文件配置。主要是resourceSet节点下的配置。
<!--defaultDuration 默认缓存的时间,单位为天数-->
<!--defaultVersion 合并后的资源版本,在你修改了资源文件后需要对版本进行修改,你可以指定auto或者手动设置一个版本号-->
<!--defaultDebugEnabled 调试的模式,为true时那么资源文件不进行压缩,开发时可以设置成true,上线后设置成false-->
第四步 删除 AppStart/Combres.cs,移除WebActivetor的引用。打开 global.asax 添加 using Combres;的引用。在 RegisterRoutes 第一行添加routes.AddCombresRoute("Combres")
第五步 在需要的视图文件进行引用,先来看一下未做修改前的文件内容
<!DOCTYPE html> <html> <head> <title>@ViewBag.Title</title> <link href= "@Url.Content(" ~/Content/Site.css ")" rel= "stylesheet" type= "text/css" /> <link href= "@Url.Content(" ~/Content/StyleSheet1.css ")" rel= "stylesheet" type= "text/css" /> <script src= "@Url.Content(" ~/Scripts/jquery-1.5.1.min.js ")" type= "text/javascript" ></script> <script src= "@Url.Content(" ~/Scripts/test.js ")" type= "text/javascript" ></script> </head> |
|
接下来是修改之后的
@ using Combres.Mvc; <!DOCTYPE html> <html> <head> <title>@ViewBag.Title</title> @Html.CombresLink( "siteCss" ) @Html.CombresLink( "siteJs" ) </head> |
siteCss和sitJs已经在上面App_Data/combres.xml进行过配置。
最后一步运行查看,这是未修改之前的
接下来看修改之后的
效果很明显,原来的四次请求,变成了两次请求。
|
js css优化-- 合并和压缩的更多相关文章
- 前端js,css文件合并三种方式,bat命令
前端js,css文件合并三种方式,bat命令 前端js文件该如何合并三个方式如下:1. 一个大文件,所有js合并成一个大文件,所有页面都引用它.2. 各个页面大文件,各自页面合并生成自己所需js的大文 ...
- [转]使用 YCombo 做 JS /CSS开发 合并 压缩
本文转自:http://www.neoease.com/minimize-javascript-files-using-ycombo/ 前文已介绍过 YCombo 及相关的 CSS 和 JS 合并工具 ...
- gulp 实现 js、css,img 合并和压缩
前提条件,知道如何安装nodejs.gulp,这里不做介绍,可以自行google 实现此功能需要安装的gulp工具有如下 npm install gulp-htmlmin gulp-imagemin ...
- 【web性能】 JS、CSS的合并、压缩、缓存管理
本篇文章主要讨论下目前JS,CSS 合并.压缩.缓存管理存在的一些问题,然后分享下自己项目中用到的1个处理方案,并提供1个实例下载. 存在的问题: 合并.压缩文件主要有2方面的问题: 1. 每次发 ...
- grunt 压缩js css html 合并等配置与操作详解
module.exports = function(grunt){ //1.引入 grunt.loadNpmTasks('grunt-contrib-cssmin'); grunt.loadNpmTa ...
- gulp 实现 js、css,img 合并和压缩(转)
前提条件,知道如何安装nodejs.gulp,这里不做介绍,可以自行google 实现此功能需要安装的gulp工具有如下 npm install gulp-htmlmin gulp-imagemin ...
- gulp打包js/css时合并成一个文件时的顺序解决
1.可以使用插进gulp-order. 2.可以这样的写法: return gulp.src(['js/common.js','js/**/*.js']) .pipe(concat('build.js ...
- 开箱即用 - Grunt合并和压缩 js,css 文件
js,css 文件合并与压缩 Grunt 是前端自动化构建工具,类似webpack. 它究竟有多强悍,请看它的 介绍. 这里只演示如何用它的皮毛功能:文件合并与压缩. 首先说下js,css 合并与压缩 ...
- requireJS中如何用r.js对js进行合并和压缩css文件
我运行的环境是windows+node.js,首先是用npm安装requirejs(全局安装,即使用 'npm install requirejs -g',这样方便在各个目录调用),接着就是下载r.j ...
随机推荐
- tomcat识别不出maven web项目
解决办法: 点中项目-->Properties-->project facets 勾选:Dynamic Web Module.java.javaScript Apply-->OK 解 ...
- unity3d 学习过程记录
通过泰克在线,开始学习视频教程 1.学习 Unity3d零基础教学初级篇:熟悉一下unity编辑器结构和控件以及对控件的基本操作 2.学习Roll-a-ball小项目开发:通过练习制作小游戏,巩固所学 ...
- ACdream 1063 平衡树
写的很丑的字典树.听王大神的话 需要改进. #include<stdio.h> #include<string.h> #include<math.h> #incl ...
- 在家用机上搭建 Git https 服务器
今天主要叙述在家里台式机的虚拟机上搭建支持 https 的 ubuntu git 服务器. 实际上,从一个用户请求家里 git 服务器代码,最终完成代码的传输,主要是通过以下的过程: 首先,从外界寻找 ...
- CSS3秘笈复习:第八章
一.背景的所有属性: 属性 作用 可选项 1.background-image 定义一张图片 url(...) 2.background-repeat 控制重复 no-repeat | repeat- ...
- ORACLE 11g dblink 配置升级
1.如果需要创建全局 DBLink,则需要先确定用户有创建 dblink 的权限: select * from user_sys_privs where privilege like upper('% ...
- hdu_5968_异或密码(预处理+二分)
题目链接:hdu_5968_异或密码 题意: 中午,不解释 题解: 前缀处理一下异或值,然后上个二分查找就行了,注意是unsigned long long #include<bits/stdc+ ...
- WCF、Web API、WCF REST、Web Service的区别
Difference between WCF and Web API and WCF REST and Web Service The .Net framework has a number of ...
- Objetive-C +load方法研究
load方法的执行时机 Objetive-C 的runtime会在一个类的所有方法加载到内存中时调用这个类的+load() 方法,因为每个类的方法只是加载一次,所以每个+load( ...
- shell脚本学习(四)
1.文件权限 1.1 用户有一个称为setuid(S)的特殊权限,它出现在执行权限(x)的位置,setuid权限允许用户以拥有者的权限来执行可执行文件,即使这个可执行文件是由 其他用户运行的. 具有s ...