转载自:http://blog.csdn.net/fangxing80/article/details/17639607

我们知道在 Web 应用开发中为了提高客户端响应速度,需要将页面使用的资源最小化,yuicompressor-maven-plugin 能够很好的实现js, css的压缩、合并处理。

先来看看工程结构:



project

└─main

    ├─java

    └─webapp

        ├─app

        │  │  index.html

        │  │  

        │  ├─css

        │  │      style.css

        │  │      

        │  └─js

        │          app1.js

        │          app2.js

        │          jquery-1.9.1.min.js

        │          

        └─WEB-INF

                web.xml

index.html 里引用 app1.js 和 app2.js, 首先通过 yuicompressor-maven-plugin 对 app1.js,app2.js 进行压缩、合并。

(http://alchim.sourceforge.net/yuicompressor-maven-plugin/index.html,需FQ)

pom.xml 配置如下,其中所有已经是 min 化的文件会被排除比如:jquery-1.9.1.min.js

[html] view
plain
copy

  1. <plugin>
  2. <groupId>net.alchim31.maven</groupId>
  3. <artifactId>yuicompressor-maven-plugin</artifactId>
  4. <version>1.3.0</version>
  5. <executions>
  6. <execution>
  7. <goals>
  8. <goal>compress</goal>
  9. </goals>
  10. </execution>
  11. </executions>
  12. <configuration>
  13. <encoding>UTF-8</encoding>
  14. <!-- 忽略 js 错误警告 -->
  15. <jswarn>false</jswarn>
  16. <nosuffix>true</nosuffix>
  17. <linebreakpos>-1</linebreakpos>
  18. <includes>
  19. <include>app/js/*.js</include>
  20. <include>app/js/*.css</include>
  21. </includes>
  22. <excludes>
  23. <exclude>**/**min.js</exclude>
  24. </excludes>
  25. <aggregations>
  26. <aggregation>
  27. <removeIncluded>true</removeIncluded>
  28. <insertNewLine>true</insertNewLine>
  29. <inputDir>${project.build.directory}/${project.build.finalName}</inputDir>
  30. <output>${project.build.directory}/${project.build.finalName}/app/js/app.pack.js</output>
  31. <includes>
  32. <include>app/js/app*.js</include>
  33. </includes>
  34. <excludes>
  35. <exclude>**/**min.js</exclude>
  36. </excludes>
  37. </aggregation>
  38. </aggregations>
  39. </configuration>
  40. </plugin>

这里我将 app1.js 和 app2.js 合并成 app.pack.js, 但光合并还不行。index.html 里仍然是引用 app1.js 和 app2.js,所以必须替换掉。

下一步用 maven-replacer-plugin 来完成替换工作。



为了通用性(你不必写死 js或者css文件名,并且支持多组的文件合并和替换),采用一个特殊的标识在 html 里来圈定要替换的js,这样就可以通过这个标识来寻找替换目标。



index.html

[html] view
plain
copy

  1. <script type="text/javascript" src="app/js/jquery-1.9.1.min.js"></script>
  2. <strong><!-- mergeTo:app.pack.js --></strong>
  3. <script type="text/javascript" src="app/js/app1.js"></script>
  4. <script type="text/javascript" src="app/js/app2.js"></script>
  5. <strong><!-- mergeTo --></strong>

如上所示,所有 <!-- mergeTo:xxx.js --> ... <!-- mergeTo --> 区间的 js 引用会被替换成 xxx.js 



增加的 maven-replacer-plugin pom
配置如下:

[html] view
plain
copy

  1. <plugin>
  2. <groupId>com.google.code.maven-replacer-plugin</groupId>
  3. <artifactId>replacer</artifactId>
  4. <version>1.5.2</version>
  5. <executions>
  6. <execution>
  7. <phase>package</phase>
  8. <goals>
  9. <goal>replace</goal>
  10. </goals>
  11. </execution>
  12. </executions>
  13. <configuration>
  14. <file>${project.build.directory}/${project.build.finalName}/app/index.html</file>
  15. <replacements>
  16. <replacement>
  17. <token>
  18. <![CDATA[
  19. <!-- mergeTo:([^\s]*) -->(.*?)<!-- mergeTo -->
  20. ]]>
  21. </token>
  22. <value>
  23. <![CDATA[
  24. <script type="text/javascript" src="$1" ></script>
  25. ]]>
  26. </value>
  27. </replacement>
  28. </replacements>
  29. <regexFlags>
  30. <regexFlag>CASE_INSENSITIVE</regexFlag>
  31. <regexFlag>DOTALL</regexFlag>
  32. </regexFlags>
  33. </configuration>
  34. </plugin>

maven-replacer-plugin 支持正则替换正好满足我的需求,注意:

(1) 替换 <!-- mergeTo:xxx.js --> 区间的时候,使用的是正则 "单行” 模式,即 DOTALL

(2) 因为 yuicompressor-maven-plugin 执行在 prepackage 所以 maven-replacer-plugin 的 phase 要修改为 package

这样在开发时,增加 js 也不用再重复修改 pom 配置,当然 js 文件命名时最好遵从一定的规则,以便在 compress 时方便筛选。

maven 压缩、合并 js, css的更多相关文章

  1. Grunt的配置及使用(压缩合并js/css)

    Grunt的配置及使用(压缩合并js/css) 安装 前提是你已经安装了nodejs和npm. 你能够在 nodejs.org 下载安装包安装.也能够通过包管理器(比方在 Mac 上用 homebre ...

  2. 前端构建工具 Gulp 压缩合并JS/CSS 并添加版本号、ES6转ES5

    Gulp 基于 Node.js 的前端构建工具,可以实现前端代码的编译(sass.less).压缩合并(JS.CSS).测试:图片的压缩:已经添加 JS 和 CSS 版本号,防止浏览器缓存. 1. 安 ...

  3. 第十一节:Bundles压缩合并js和css及原理分析

    一. 简介 1.背景:浏览器默认一次性请求的网络数是有上限的,如果你得js和css文件太多,就会导致浏览器需要多次加载,影响页面的加载速度, MVC中提供Bundles的方式压缩合并js和css,是M ...

  4. 引用:使用grunt 压缩 合并js、css文件

    引用:https://www.jianshu.com/p/08c7babdec65 压缩 js 文件 1.创建一个目录 名为grunt   目录.png 2.在grunt目录下创建一个 src目录,存 ...

  5. 使用PHP和GZip压缩网站JS/CSS文件加速网站访问速度

    使用PHP和GZip压缩网站JS/CSS文件加速网站访问速度 一些泛WEB 2.0网站为了追求用户体验,可能会大量使用CSS和JS文件.这就导致在服务器带宽一定的情况下,多用户并发访问速度变慢.如何加 ...

  6. Google Pagespeed,自动压缩优化JS/CSS/Image

    Google Pagespeed,自动压缩优化JS/CSS/Image 浏览: 发布日期:// 分类:技术分享 关键字: Nginx Appache Pagespeed 自动压缩优化JS/CSS/Im ...

  7. 自写脚本实现上线前本地批量压缩混淆 js , css 代码。

    最近做项目遇到一个要求,就是把本地的 js 和 css 进行压缩后再上线,由于之前项目并没有使用 webpack 之类的库,项目上也因为一些机密不能在线上压缩,这无疑给代码打包压缩带来了很大麻烦,于是 ...

  8. Web性能优化之动态合并JS/CSS文件并缓存客户端

    来源:微信公众号CodeL 在Web开发过程中,会产生很多的js/css文件,传统的引用外部文件的方式会产生多次的http请求,从而加重服务器负担且网页加载缓慢,如何在一次请求中将多个文件一次加载出来 ...

  9. 利用nginx concat模块合并js css

    前言: nginx-http-concat模块是由淘宝网开发的,现在淘宝网合并js和css正是用这个模块,如链接http://a.tbcdn.cn/??s/kissy/1.2.0/kissy-min. ...

随机推荐

  1. [转]URL传中文参数导致乱码的解决方案之encodeURI

    通过URL传中文参数时,在服务端后台获取到的值往往会出现乱码.解决方案有很多种.本文介绍如何通过encodeURI来解决中文乱码问题. 首先,在前端页面准备参数的时候,需要对中文参数进行encode处 ...

  2. jsp 路径问题和环境路径以及各种路径总结

    首先确定问题: 浏览器发送请求后,服务器会返回一个响应,但是返回的网页中,会有各种路径问题,所以在此用jsp中的属性来解决.(只是记录问题,用了不专业的术语,请见谅.) 总结: 以路径  http:/ ...

  3. Jmeter中传递cookie值

    场景:用户登陆后会本地会保存cookie,cookie是用来跟服务端验证此用户已经登陆过的重要信息,但是如何获取并在其他请求时将此cookie传递给服务器呢? 在线程组下面之直接添加HTTP Cook ...

  4. 问题 A: 完数

    问题 A: 完数 时间限制: 1 Sec  内存限制: 32 MB提交: 252  解决: 178[提交][状态][讨论版][命题人:外部导入] 题目描述 求1-n内的完数,所谓的完数是这样的数,它的 ...

  5. ubuntu中tensorflow安装

    首先加入了CUDA_HOM环境变量,然后下载了一个分析工具库,结果E: 无法定位软件包 libcupti-dev,在etc/apt 的sources.list 添加镜像源 deb http://arc ...

  6. Docker 安装Neo4j

    拉取最新的neo4j镜像 docker pull neo4j 运行Neo4j 容器 docker run -it -d -p 7474:7474 -p 7687:7687 neo4j:latest 打 ...

  7. CCS Font 知识整理总结

    总是搞不懂 CCS 中如何正确的使用字体,这下明白了. 1.什么是 font-face font-face 顾名思义,就是文字的脸.字体是文字的外在形式,就是文字的风格,是文字的外衣.比如行书.楷书. ...

  8. [leetcode-648-Replace Words]

    In English, we have a concept called root, which can be followed by some other words to form another ...

  9. ubuntu中执行truffle build出现问题

    进行build之前,采用默认构建器方式创建客户端,先安装默认构建器: npm install truffle-default-builder --save 然后需要修改truffle.js配置文件如下 ...

  10. oracle dg 备库不同步主库数据

    今天遇到一个数据库同步问题,主库被关闭,重启主库后,备库不能正常同步主库数据.只有当手动切换归档日志的时候,备库才能和主库一致. 这个问题的解决方法: 重启备库,重新应用归档日志. 操作步骤如下: / ...