java 压缩js css_yui压缩JS和CSS文件

2023-10-18 12:10
文章标签 java css js 压缩 frontend yui

本文主要是介绍java 压缩js css_yui压缩JS和CSS文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CSS和JS文件经常需要压缩,比如我们看到的XX.min.js是经过压缩的JS。

压缩文件第一个是可以减小文件大小,第二个是对于JS文件,默认会去掉所有的注释,而且会去掉所有的分号,也会将我们的一些参数替换为一些简单的a,b之类的变量,从界面看起来非常难阅读,起到加密作用。

常见的有好多压缩工具,这里使用yui进行压缩,首先需要下载yui的包:  yuicompressor-2.4.7.jar  ,可以到我的服务器下载:http://qiaoliqiang.cn/fileDown/yuicompressor-2.4.7.zip

1.查看yui使用帮助:

G:\>java -jar yuicompressor-2.4.7.jar

Usage: java-jar yuicompressor-x.y.z.jar [options] [input file]

Global Options-h, --help Displays thisinformation--type Specifies the type of the input file--charset Read the input file using

--line-break Insert a line breakafter the specified column number-v, --verbose Display informational messages and warnings-o Place the output into . Defaults to stdout.

Multiple files can be processed using the following syntax:

java-jar yuicompressor.jar -o '.css$:-min.css' *.css

java-jar yuicompressor.jar -o '.js$:-min.js' *.js

JavaScript Options--nomunge Minify only, donot obfuscate--preserve-semi Preserve all semicolons--disable-optimizations Disable all micro optimizations

If no input file is specified, it defaults to stdin. Inthis case, the 'type'option is required. Otherwise, the'type' option is required only ifthe input

file extension is neither'js' nor 'css'.

2.压缩JS:

默认会去掉所有的注释,而且会去掉所有的分号,也会将我们的一些参数替换为一些简单的a,b之类的变量,起到加密作用。

JS内容:

/**

* 验证密码和账户*/

functionvalidate2(username, password) {if (username != "zhangsan") {

alert("userName is error:" +c)

}if (password != "123456") {

alert("password is error:" +d)

}

};

源文件大小:220字节

进行压缩:

G:\>java -jar yuicompressor-2.4.7.jar index.js -v -o index-min.js --charset UTF-8

参数解释:

index.js 需要压缩的源文件

-v -o 显示信息与指定输出文件名字

index-min.js 压缩后的文件

--charset 指定编码格式

压缩后文件内容和大小:(被压缩成一行,注释被去掉,分号也被去掉)

function validate2(b,a){if(b!="zhangsan"){alert("userName is error:"+c)}if(a!="123456"){alert("password is error:"+d)}};

大小为:120字节

我们也可以保留分号:    --preserve-semi 参数

G:\>java -jar yuicompressor-2.4.7.jar index.js -v --preserve-semi -o index-min.js --charset UTF-8[WARNING] The symbol c is declared but is apparently never used.

This code can probably be writtenina more compact way.

username!="zhangsan"){alert("userName is error:"+ ---> c

[WARNING] The symbol d is declared but is apparently never used.

This code can probably be writtenina more compact way.

password!="123456"){alert("password is error:"+ ---> d

压缩后内容:

function validate2(b,a){if(b!="zhangsan"){alert("userName is error:"+c);}if(a!="123456"){alert("password is error:"+d);}}

3.压缩CSS

G:\>java -jar yuicompressor-2.4.7.jar index.css -v -o index1-min.css --charset UTF-8

也可以写成bat脚本进行压缩JS和css,此处就不写了。

接下来研究Java中调用yui压缩JS和css。原理是Java调用RuntTime执行cmd中的一些命令,只是写了个for循环遍历文件夹下main的css和js文件进行遍历。同样依赖上面的jar包:

工具类如下:

packagezdComputerTest;importjava.io.File;importjava.io.IOException;importjava.util.ArrayList;importjava.util.Arrays;importjava.util.Date;importjava.util.List;/*** 通过yuicompressor压缩JS|CSS文件工具类

*@authorAdministrator

**/

public classCompressUtils {private static final String encoding = "utf-8";private static final String[] suffixArray = { ".js", ".css"};public static voidmain(String[] args) {

String yuiPath= "G:/yuicompressor-2.4.7.jar";

String filePath= "G:/js";

compressFile(yuiPath, filePath);

}/*** 压缩指定文件夹下所有的js/css

*

*@paramyuiPath

* yuicompressor-2.4.7.jar文件路径

*@paramfilePath

* 要压缩的文件夹路径*/

public static voidcompressFile(String yuiPath, String filePath) {

File file= newFile(filePath);

List commondList = new ArrayList();

initCommondList(yuiPath, commondList, file);

excuteCompress(commondList);

}/*** 执行压缩命令

*@paramcommondList*/

private static void excuteCompress(ListcommondList) {

Runtime runTime=Runtime.getRuntime();

Date startTime= newDate();

Long count= 0L;for(String cmd : commondList) {try{

System.out.println(cmd);

runTime.exec(cmd);

count++;

}catch(IOException e) {

e.printStackTrace();

}

}

Date endTime= newDate();

Long cost= endTime.getTime() -startTime.getTime();

System.out.println("压缩完成,耗时:" + cost + "ms,共压缩文件个数:" +count);

}/*** 初始化压缩命令

*@paramyuiPath

*@paramcommondList

*@paramfile*/

private static voidinitCommondList(String yuiPath,

ListcommondList, File file) {if(file.isDirectory()) {

File[] files=file.listFiles();//如果某个文件夹是空文件夹,则跳过

if (files == null) {return;

}for(File f : files) {

initCommondList(yuiPath, commondList, f);

}

}else{

String fileName=file.getName();

String suffix= fileName.substring(fileName.lastIndexOf("."),

fileName.length());

List suffixList =Arrays.asList(suffixArray);if(suffixList.contains(suffix)&& !fileName.endsWith("-min" +suffix)) {

StringBuffer sb= newStringBuffer();

sb.append("java -jar ");

sb.append(yuiPath);

sb.append(" --type ");

sb.append(suffix.substring(suffix.indexOf(".") + 1));

sb.append(" --charset ");

sb.append(encoding).append(" ");

sb.append(file.getPath()).append(" ");

sb.append("-o").append(" ");

sb.append(file.getPath().replace(suffix,"-min" +suffix));

commondList.add(sb.toString());

}

}

}

}

4.Ant整合yui压缩JS的脚本

项目结构:

e4101cd3461b04f82ceb3d7a3706485c.png

build.xml脚本:(此脚本可以编译项目中的src下的文件和压缩JS和CSS)

build.properties

tomcatPath=E:/tomcat/apache-tomcat-7.0.72jarName=commons-exam-code

jarNumber=1.0.1examJsRootPath=${basedir}/WebContent/js

这篇关于java 压缩js css_yui压缩JS和CSS文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/232496

相关文章

Java方法重载与重写之同名方法的双面魔法(最新整理)

《Java方法重载与重写之同名方法的双面魔法(最新整理)》文章介绍了Java中的方法重载Overloading和方法重写Overriding的区别联系,方法重载是指在同一个类中,允许存在多个方法名相同... 目录Java方法重载与重写:同名方法的双面魔法方法重载(Overloading):同门师兄弟的不同绝

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

Java中ArrayList与顺序表示例详解

《Java中ArrayList与顺序表示例详解》顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构,:本文主要介绍Java中ArrayList与... 目录前言一、Java集合框架核心接口与分类ArrayList二、顺序表数据结构中的顺序表三、常用代码手动

JAVA项目swing转javafx语法规则以及示例代码

《JAVA项目swing转javafx语法规则以及示例代码》:本文主要介绍JAVA项目swing转javafx语法规则以及示例代码的相关资料,文中详细讲解了主类继承、窗口创建、布局管理、控件替换、... 目录最常用的“一行换一行”速查表(直接全局替换)实际转换示例(JFramejs → JavaFX)迁移建

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

JAVA线程的周期及调度机制详解

《JAVA线程的周期及调度机制详解》Java线程的生命周期包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED,线程调度依赖操作系统,采用抢占... 目录Java线程的生命周期线程状态转换示例代码JAVA线程调度机制优先级设置示例注意事项JAVA线程

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位

springboot的controller中如何获取applicatim.yml的配置值

《springboot的controller中如何获取applicatim.yml的配置值》本文介绍了在SpringBoot的Controller中获取application.yml配置值的四种方式,... 目录1. 使用@Value注解(最常用)application.yml 配置Controller 中