ANT 压缩(去掉空格/注释)JS文件可提高js运行速度


Posted in Javascript onApril 15, 2013

1、说明在使用extjs 的时候,运行起来比较卡,特别是运行数据和js过多的时候,就会出现卡死的情况,或者等待时间比较长。
在解决这个有很多优化方法,今天来说其中一种,那就是在Ant脚本打包的时候,把js中空格、注释去掉、以及合并,合并今天不说了,还未实现这个,在研究中
2、首先,需要准备二个 .jar 文件,分别是 YUIAnt.jar 和 yuicompressor-2.4.x.jar 。
3、俩个文件的附件
下载地址
4、build.xml文件如下

<!-- JS压缩过程中的临时目录 --> 
<property name="jsDir" value="${basedir}/release/web/js" /> 
<!-- CSS压缩过程中的临时目录 --> 
<property name="cssDir" value="${basedir}/release/web/css" /> 
<!-- ext3 css压缩过程中的临时目录 --> 
<property name="cssExtDir" value="${basedir}/release/web/ext3" /> 
<!-- ext3 js压缩过程中的临时目录 --> 
<property name="extUxJsDir" value="${basedir}/release/web/ext3/ux" /> 
<!-- JS源文件 --> 
<property name="jsSourceDir" value="${webapp}/js" /> 
<!-- CSS源文件 --> 
<property name="cssSourceDir" value="${webapp}/css" /> 
<!-- Ext CSS源文件 --> 
<property name="cssExtSourceDir" value="${webapp}/ext3" /> 
<!-- Ext JS源文件 --> 
<property name="extUxJsSourceDir" value="${webapp}/ext3/ux" /> 
<!-- yui 依赖包 --> 
<path id="yuiClasspath"> 
<fileset dir="${basedir}"> 
<include name="metadata/tools/yui/yuicompressor-2.4.2.jar" /> 
<include name="metadata/tools/yui/YUIAnt-zh_CN.jar" /> 
</fileset> 
</path>

<!-- 开始压缩JS --> 
<target name="copy-web-depress-js" depends="init"> 
<delete dir="${basedir}/release/web" /> 
<copy todir="${basedir}/release/web"> 
<fileset dir="${webapp}"/> 
</copy> 
<taskdef name="uxJsCompress" classname="com.yahoo.platform.yui.compressor.YUICompressTask"> 
<classpath> 
<path refid="yuiClasspath" /> 
</classpath> 
</taskdef> 
<uxJsCompress linebreak="9000000" warn="false" charset="utf-8" encoding="utf-8" munge="yes" preserveallsemicolons="true" outputfolder="${extUxJsDir}"> 
<fileset dir="${extUxJsSourceDir}"> 
<include name="**/*.js" /> 
</fileset> 
</uxJsCompress> 
<taskdef name="yuicompress" classname="com.yahoo.platform.yui.compressor.YUICompressTask"> 
<classpath> 
<path refid="yuiClasspath" /> 
</classpath> 
</taskdef> 
<yuicompress linebreak="9000000" warn="false" charset="utf-8" encoding="utf-8" munge="yes" preserveallsemicolons="true" outputfolder="${jsDir}"> 
<fileset dir="${jsSourceDir}"> 
<include name="**/*.js" /> 
</fileset> 
</yuicompress> 
<taskdef name="cssYuicompress" classname="com.yahoo.platform.yui.compressor.YUICompressTask"> 
<classpath> 
<path refid="yuiClasspath" /> 
</classpath> 
</taskdef> 
<cssYuicompress linebreak="9000000" warn="false" charset="utf-8" encoding="utf-8" munge="yes" preserveallsemicolons="true" outputfolder="${cssDir}"> 
<fileset dir="${cssSourceDir}"> 
<include name="**/*.css" /> 
</fileset> 
</cssYuicompress> 
<taskdef name="cssExtYuicompress" classname="com.yahoo.platform.yui.compressor.YUICompressTask"> 
<classpath> 
<path refid="yuiClasspath" /> 
</classpath> 
</taskdef> 
<cssExtYuicompress linebreak="9000000" warn="false" charset="utf-8" encoding="utf-8" munge="yes" preserveallsemicolons="true" outputfolder="${cssExtDir}"> 
<fileset dir="${cssExtSourceDir}"> 
<include name="**/*.css" /> 
</fileset> 
</cssExtYuicompress> 
</target> 
<!-- 结束压缩JS -->

5、在这里说一点,在使用js压缩的时候YUIAnt.jar 是不支持utf-8字符集的。即
encoding="utf-8

下载地址
7、个人感受,在弄了很小半天,吧这个问题搞定了,自以为可以提高点js加载速度了,结果还是有点小慢,没有jquery那么的快,估计要用gzjs压缩才会变快点,现在我分析是的在IE下运行速度比较慢点,在firefox下比较快,看来还是每个模块加载的js有点多。
优化速度对比:
ANT 压缩(去掉空格/注释)JS文件可提高js运行速度
Javascript 相关文章推荐
Jquery作者John Resig自己封装的javascript 常用函数
Nov 09 Javascript
当自定义数据属性为json格式字符串时jQuery的data api问题探讨
Feb 18 Javascript
基于JavaScript 数据类型之Boolean类型分析介绍
Apr 19 Javascript
在JavaScript中处理数组之reverse()方法的使用
Jun 09 Javascript
js+html5实现的自由落体运动效果代码
Jan 28 Javascript
JS图片压缩(pc端和移动端都适用)
Jan 12 Javascript
收藏AngularJS中最重要的核心功能
Jul 09 Javascript
浅谈Node.js CVE-2017-14849 漏洞分析(详细步骤)
Nov 10 Javascript
JavaScript callback回调函数用法实例分析
May 08 Javascript
详解Vue 全局变量,局部变量
Apr 17 Javascript
js针对图片加载失败的处理方法分析
Aug 24 Javascript
ES2020 新特性(种草)
Jan 12 Javascript
Extjs优化(一)删除冗余代码提高运行速度
Apr 15 #Javascript
Extjs Gird 支持中文拼音排序实现代码
Apr 15 #Javascript
jquery+css+ul模拟列表菜单具体实现思路
Apr 15 #Javascript
js作用域及作用域链概念理解及使用
Apr 15 #Javascript
利用百度地图JSAPI生成h7n9禽流感分布图实现代码
Apr 15 #Javascript
jquery分页插件AmSetPager(自写)
Apr 15 #Javascript
Extjs 继承Ext.data.Store不起作用原因分析及解决
Apr 15 #Javascript
You might like
PHP 和 MySQL 基础教程(四)
2006/10/09 PHP
PHP中如何调用webservice的实例参考
2013/04/25 PHP
PHP 实现页面静态化的几种方法
2017/07/23 PHP
PHP7扩展开发教程之Hello World实现方法示例
2017/08/03 PHP
PHP实现求解最长公共子串问题的方法
2017/11/17 PHP
HR vs ForZe BO3 第二场 2.13
2021/03/10 DOTA
jquery 之 $().hover(func1, funct2)使用方法
2012/06/14 Javascript
javascript实现多级联动下拉菜单的方法
2015/02/06 Javascript
NodeJS实现阿里大鱼短信通知发送
2016/01/17 NodeJs
简单实现bootstrap导航效果
2017/02/07 Javascript
canvas仿iwatch时钟效果
2017/03/06 Javascript
js oncontextmenu事件使用详解
2017/03/25 Javascript
jQuery滚动条美化插件nicescroll简单用法示例
2018/04/18 jQuery
详解js跨域请求的两种方式,支持post请求
2018/05/05 Javascript
angularjs http与后台交互的实现示例
2018/12/21 Javascript
基于js Canvas实现二次贝塞尔曲线
2018/12/25 Javascript
[00:32]2018DOTA2亚洲邀请赛出场——VP
2018/04/04 DOTA
python批量修改图片后缀的方法(png到jpg)
2018/10/25 Python
使用PM2+nginx部署python项目的方法示例
2018/11/07 Python
python实现归并排序算法
2018/11/22 Python
python的几种矩阵相乘的公式详解
2019/07/10 Python
Python中的类与类型示例详解
2019/07/10 Python
python在新的图片窗口显示图片(图像)的方法
2019/07/11 Python
python修改FTP服务器上的文件名
2019/09/11 Python
css3 中的新特性加强记忆详解
2016/04/16 HTML / CSS
群众路线查摆问题整改措施思想汇报
2014/10/10 职场文书
离婚协议书样本
2015/01/26 职场文书
停水通知
2015/04/16 职场文书
月考总结与反思
2015/10/22 职场文书
施工安全责任协议书
2016/03/23 职场文书
标准版个人借条怎么写?以及什么是借条?
2019/08/28 职场文书
教你用python实现12306余票查询
2021/06/30 Python
Python中三种花式打印的示例详解
2022/03/19 Python
CKAD认证中部署k8s并配置Calico插件
2022/03/31 Servers
基于Python实现对比Exce的工具
2022/04/07 Python
Linux中一对多配置日志服务器的详细步骤
2022/07/23 Servers