项目采用maven构建的时候,需要压缩js,css等,网上找了相关资料,自己综合了下~
直接放代码:
<!-- js压缩 -->
<plugin>
<groupId>net.alchim31.maven</groupId>
<artifactId>yuicompressor-maven-plugin</artifactId>
<version>1.3.0</version>
<executions>
<execution>
<phase>install</phase>
<goals>
<goal>compress</goal>
</goals>
<configuration>
<excludes>
<exclude>**/*.min.js</exclude>
<exclude>**/*-min.js</exclude>
</excludes>
<nosuffix>true</nosuffix>
<linebreakpos>-1</linebreakpos>
</configuration>
</execution>
</executions>
</plugin>
<!-- native2ascii -->
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>native2ascii-maven-plugin</artifactId>
<version>1.0-beta-1</version>
<executions>
<execution>
<phase>install</phase>
<goals>
<goal>native2ascii</goal>
</goals>
<configuration>
<workDir>${project.build.directory}/${project.build.finalName}</workDir>
<excludes>
<exclude>**/*.css</exclude>
</excludes>
<includes>
<include>resources/js/*.js</include>
</includes>
</configuration>
</execution>
</executions>
</plugin>
更喜欢采用谷歌的closure-compiler + maven-antrun-plugin
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<version>2.4</version>
<executions>
<execution>
<phase>validate</phase>
<goals>
<goal>copy</goal>
</goals>
<configuration>
<artifactItems>
<artifactItem>
<groupId>com.google.javascript</groupId>
<artifactId>closure-compiler</artifactId>
<version>r1810</version>
<type>jar</type>
<overWrite>true</overWrite>
<outputDirectory>${project.build.directory}/compressor</outputDirectory>
<destFileName>closure-compiler.jar</destFileName>
</artifactItem>
<artifactItem>
<groupId>com.yahoo.platform.yui</groupId>
<artifactId>yuicompressor</artifactId>
<version>2.4.6</version>
<type>jar</type>
<overWrite>true</overWrite>
<outputDirectory>${project.build.directory}/compressor</outputDirectory>
<destFileName>yuicompressor.jar</destFileName>
</artifactItem>
</artifactItems>
</configuration>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-antrun-plugin</artifactId>
<version>1.7</version>
<executions>
<execution>
<phase>install</phase>
<goals>
<goal>run</goal>
</goals>
<configuration>
<tasks>
<echo message="开始压缩 JS 文件. 请耐心等待!" />
<property name="yuicompressor" value="${project.build.directory}/compressor/yuicompressor.jar" />
<property name="closure-compiler" value="${project.build.directory}/compressor/closure-compiler.jar" />
<property name="css.compress.directory" value="${project.build.directory}/${project.build.finalName}/resources" />
<property name="js.compress.directory" value="${css.compress.directory}/js" />
<apply executable="java" parallel="false" failonerror="true" dest="${js.compress.directory}">
<fileset dir="${js.compress.directory}" includes="**/*.js" />
<arg line="-jar" />
<arg path="${closure-compiler}" />
<arg line="--warning_level DEFAULT" />
<arg line="--compilation_level SIMPLE_OPTIMIZATIONS" />
<arg line="--js" />
<srcfile />
<arg line="--js_output_file" />
<targetfile />
<mapper type="regexp" from="^(.*)\.(js)$" to="\1-min.\2" />
</apply>
<move todir="${js.compress.directory}">
<fileset dir="${js.compress.directory}" includes="**/*.js" />
<mapper type="regexp" from="^(.*)-min\.(js)$" to="\1.\2" />
</move>
<echo message="成功压缩 JS 文件" />
<echo message="开始压缩 CSS 文件. 请耐心等待!" />
<apply executable="java" parallel="false" failonerror="true" dest="${css.compress.directory}">
<fileset dir="${css.compress.directory}" includes="**/*.css" />
<arg line="-jar" />
<arg path="${yuicompressor}" />
<arg line="--charset UTF-8" />
<arg value="--type"/>
<arg value="css"/>
<srcfile />
<arg line="-o" />
<targetfile />
<mapper type="regexp" from="^(.*)\.(css)$" to="\1-min.\2" />
</apply>
<move todir="${css.compress.directory}">
<fileset dir="${css.compress.directory}" includes="**/*.css" />
<mapper type="regexp" from="^(.*)-min\.(css)$" to="\1.\2" />
</move>
<echo message="成功压缩 CSS 文件" />
</tasks>
</configuration>
</execution>
</executions>
</plugin>
JQUERY 的压缩工具 uglifyjs版本的配置,必须要有nodejs环境 (executable="node")即在cmd中能够执行 node --version. uglifyjs可以在https://github.com/mishoo/UglifyJS 下载,下载后续稍稍修改bin/uglifyjs,把里面的
var uglify = require("uglify-js")
修改为
var uglify = require("./uglify-js");//或者 ../uglify-js
因为uglify-js默认是在bin目录外面的。
如需更新uglify的版本,每次覆盖相应文件,只修改上面文件即可。
<echo message="开始压缩 JS 文件. 请耐心等待!" />
<property name="uglifyjs" value="${project.build.directory}/compressor/uglify/uglifyjs" />
<property name="yuicompressor" value="${project.build.directory}/compressor/yuicompressor.jar" />
<property name="closure-compiler" value="${project.build.directory}/compressor/closure-compiler.jar" />
<property name="css.compress.directory" value="${project.build.directory}/${project.build.finalName}/resources" />
<property name="js.compress.directory" value="${css.compress.directory}/js" />
<apply executable="node" parallel="false" failonerror="true" dest="${js.compress.directory}">
<fileset dir="${js.compress.directory}" includes="**/*.js" />
<arg line=" ${uglifyjs}" />
<arg line=" --ascii" />
<arg line=" -o" />
<targetfile />
<srcfile />
<mapper type="regexp" from="^(.*)\.(js)$" to="\1-min.\2" />
</apply>
<move todir="${js.compress.directory}">
<fileset dir="${js.compress.directory}" includes="**/*.js" />
<mapper type="regexp" from="^(.*)-min\.(js)$" to="\1.\2" />
</move>
- uglify.7z (40.5 KB)
- 描述: uglify文件夹下的文件
- 下载次数: 126
分享到:
相关推荐
`yuicompressor-maven-plugin`是一款强大的Maven插件,主要用于优化前端资源,特别是JavaScript和CSS文件。这个插件是基于YUI Compressor,一个由Yahoo开发的开源工具,它能有效地压缩和混淆代码,从而减少文件大小...
UglifyJS与Closure Compiler类似,也可以压缩和优化JavaScript代码,但它们的压缩策略和优化程度可能有所不同。虽然这里没有具体说明如何使用UglifyJS,但可以类比Closure Compiler的集成方法,将UglifyJS作为替代...
yuicompressor-maven-plugin, 用于压缩 (Minify/Ofuscate/Aggregate) Javascript文件和使用 YUI 压缩器的CSS文件的Maven 插件 [[Flattr this git repo] ( http://api.flattr.com/button/flattr-badge-large.png)]...
在Eclipse环境中,开发者可以方便地使用此插件在构建项目时自动对.js和.css文件进行压缩,简化了手动压缩的工作流程。 ### 4. 使用步骤 - **配置插件**:在Maven的`pom.xml`文件中添加`yuicompressor-maven-plugin`...
Closure Compiler Maven 插件是开发JavaScript应用程序的一个强大工具,它集成在Maven构建流程中,利用Google的Closure Compiler对JavaScript代码进行优化和压缩。Closure Compiler以其先进的语法分析和优化技术著称...
Java中实现js和css压缩,通常会使用一些开源库,例如Google的Closure Compiler和YUI Compressor,它们提供了API供开发者调用。这些工具不仅能够压缩文件,还能进行变量和函数名的混淆,进一步减小文件大小,但混淆...
`maven-compiler-plugin-3.8.0-source-release` 版本是 Maven 编译插件的一个特定版本,该版本包含了对 Maven 3.x 系列的支持。这个插件的主要任务包括: 1. **源代码编译**:默认使用 JDK 的 `javac` 编译器进行 ...
在现代Web开发中,优化网页性能是至关重要的,其中一项策略就是对CSS和JavaScript文件进行压缩,以减少页面加载时间。Maven作为一个强大的Java项目管理工具,提供了与各种构建优化工具集成的能力,其中包括使用YUI ...
赠送Maven依赖信息文件:commons-compiler-3.1.4.pom; 包含翻译后的API文档:commons-compiler-3.1.4-javadoc-API文档-中文(简体)版.zip; Maven坐标:org.codehaus.janino:commons-compiler:3.1.4; 标签:...
maven是个项目管理工具,如果我们不告诉它我们的代码要使用什么样的jdk版本编译的话,它就会用maven-compiler-plugin默认的jdk版本来进行处理,这样就容易出现版本不匹配,以至于可能导致编译不通过的问题。...
赠送Maven依赖信息文件:commons-compiler-3.0.8.pom; 包含翻译后的API文档:commons-compiler-3.0.8-javadoc-API文档-中文(简体)版.zip; Maven坐标:org.codehaus.janino:commons-compiler:3.0.8; 标签:...
标题与描述概述的知识点是关于如何使用Maven与YUI Compressor插件来压缩JavaScript(JS)和CSS文件。在大型项目中,压缩这些文件可以显著减少加载时间,提高网站性能,同时也便于资源的管理。 ### Maven与YUI ...
Maven更新问题 今天Maven在更新的时候发现一直更新不成功,总结下解决方法。 在apache-maven-3.5.2/conf/setting.xml中加入以下配置即可解决 alimaven aliyun maven ...
赠送Maven依赖信息文件:scala-compiler-2.11.8.pom; 包含翻译后的API文档:scala-compiler-2.11.8-javadoc-API文档-中文(简体)-英语-对照版.zip; Maven坐标:org.scala-lang:scala-compiler:2.11.8; 标签:scala...
maven-compiler-plugin-3.8.0.jar
《深入解析Maven编译插件:maven-compiler-plugin-2.0.2.jar》 在Java开发领域,Maven作为一个强大的项目管理和构建工具,极大地简化了项目的构建过程。而Maven的核心就在于其插件系统,其中maven-compiler-plugin...
赠送Maven依赖信息文件:commons-compiler-2.7.6.pom; 包含翻译后的API文档:commons-compiler-2.7.6-javadoc-API文档-中文(简体)版.zip; Maven坐标:org.codehaus.janino:commons-compiler:2.7.6; 标签:...
maven-aether-provider-3.2.1-sources.jar maven-antrun-plugin-1.3.jar maven-archiver-2.2.jar maven-artifact-3.2.1-sources.jar maven-assembly-plugin-2.2-beta-5.jar maven-bundle-plugin-1.0.0.jar maven-...
`YUI Compressor` 的主要功能是对JavaScript和CSS文件进行压缩,去除代码中的空白、注释和不必要的字符。它使用了高效的代码混淆算法,将变量名替换为简短的单字母形式,进一步减小文件体积。同时,对于CSS,它还会...
赠送Maven依赖信息文件:commons-compiler-3.1.2.pom; 包含翻译后的API文档:commons-compiler-3.1.2-javadoc-API文档-中文(简体)版.zip; Maven坐标:org.codehaus.janino:commons-compiler:3.1.2; 标签:...