转载自: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. Android面试收集录 数据库

    1.SQLite数据库如何查询表table1的第20条到30条记录? select * from table1 limit 19,11   ==>从19开始,11个数据 2.如何才能将table ...

  2. 4.HBASE数据迁移方案(之snapshot):

    4.HBASE数据迁移方案:  4.1 Import/Export  4.2 distcp  4.3 CopyTable  4.4 snapshot 快照方式迁移(以USER_info:user_lo ...

  3. 「学习记录」《数值分析》第二章计算实习题(Python语言)

    在假期利用Python完成了<数值分析>第二章的计算实习题,主要实现了牛顿插值法和三次样条插值,给出了自己的实现与调用Python包的实现--现在能搜到的基本上都是MATLAB版,或者是各 ...

  4. ASP NET Core --- HTTP 翻页、过滤、排序

    参照 草根专栏- ASP.NET Core + Ng6 实战:https://v.qq.com/x/page/v07647j3zkq.html 翻页, 过滤, 排序等 – 如何传递参数? Query ...

  5. [CH5302]金字塔

    题面 虽然探索金字塔是极其老套的剧情,但是有一队探险家还是到了某金字塔脚下.经过多年的研究,科学家对这座金字塔的内部结构已经有所了解.首先,金字塔由若干房间组成,房间之间连有通道.如果把房间看作节点, ...

  6. P4332三叉神经树

    题面 \(Solution\) 通过模拟,我们会发现每次修改 \(x\),只会改变从 \(x\) 向上一段连续的链的输出. 例如将 \(x\) 点从 \(0\) 改为 \(1,\) 那么它会影响从它向 ...

  7. HDU 4588 Count The Carries(数学统计)

    Description One day, Implus gets interested in binary addition and binary carry. He will transfer al ...

  8. Hadoop2.6.0伪分布式搭建

    环境: 1.Ubuntu14.04 首先要在linux系统上新建一个账户,比如就叫做hadoop,用于专门运行hadoop. 2.配置jdk 我是使用的版本是jdk1.8. 解压:创建/usr/jav ...

  9. java获取本机器的IP(linux和windows)

    目录 描述 方案描述 获取Windows下的IP 获取linux下的IP 判断操作系统的类型 最后将上面三个方法进行整合 参考 描述 由于项目是部署在集群上的,需要项目能够自动采集各机器的信息.jav ...

  10. lintcode-79-最长公共子串

    79-最长公共子串 给出两个字符串,找到最长公共子串,并返回其长度. 注意事项 子串的字符应该连续的出现在原字符串中,这与子序列有所不同. 样例 给出A="ABCD",B=&quo ...