ANT 压缩(去掉空格/注释)JS文件可提高js运行速度_Javascript教程-查字典教程网
ANT 压缩(去掉空格/注释)JS文件可提高js运行速度
ANT 压缩(去掉空格/注释)JS文件可提高js运行速度
发布时间:2017-01-14 来源:查字典编辑
摘要:1、说明在使用extjs的时候,运行起来比较卡,特别是运行数据和js过多的时候,就会出现卡死的情况,或者等待时间比较长。在解决这个有很多优化...

1、说明在使用extjs 的时候,运行起来比较卡,特别是运行数据和js过多的时候,就会出现卡死的情况,或者等待时间比较长。

在解决这个有很多优化方法,今天来说其中一种,那就是在Ant脚本打包的时候,把js中空格、注释去掉、以及合并,合并今天不说了,还未实现这个,在研究中

2、首先,需要准备二个 .jar 文件,分别是 YUIAnt.jar 和 yuicompressor-2.4.x.jar 。

3、俩个文件的附件

下载地址

4、build.xml文件如下

复制代码 代码如下:

<>

<property name="jsDir" value="${basedir}/release/web/js" />

<>

<property name="cssDir" value="${basedir}/release/web/css" />

<>

<property name="cssExtDir" value="${basedir}/release/web/ext3" />

<>

<property name="extUxJsDir" value="${basedir}/release/web/ext3/ux" />

<>

<property name="jsSourceDir" value="${webapp}/js" />

<>

<property name="cssSourceDir" value="${webapp}/css" />

<>

<property name="cssExtSourceDir" value="${webapp}/ext3" />

<>

<property name="extUxJsSourceDir" value="${webapp}/ext3/ux" />

<>

<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>

复制代码 代码如下:

<>

<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>

<>

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

复制代码 代码如下:

encoding="utf-8

下载地址

7、个人感受,在弄了很小半天,吧这个问题搞定了,自以为可以提高点js加载速度了,结果还是有点小慢,没有jquery那么的快,估计要用gzjs压缩才会变快点,现在我分析是的在IE下运行速度比较慢点,在firefox下比较快,看来还是每个模块加载的js有点多。

优化速度对比:

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新Javascript教程学习
    热门Javascript教程学习
    编程开发子分类