ANT 压缩(去掉空格/注释)JS文件可提高js运行速度
程序员文章站
2022-06-17 17:10:44
1、说明在使用extjs 的时候,运行起来比较卡,特别是运行数据和js过多的时候,就会出现卡死的情况,或者等待时间比较长。 在解决这个有很多优化方法,今天来说其中一种,那就...
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中空格、注释去掉、以及合并,合并今天不说了,还未实现这个,在研究中
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有点多。
优化速度对比:
上一篇: 一个功能还算完整的数据库操作类
下一篇: 设计模式之十 状态模式