• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

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

    发布者: 怀卉1097 | 发布时间: 2025-8-13 15:37| 查看数: 81| 评论数: 0|帖子模式

    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有点多。
    优化速度对比:

    来源:互联网
    免责声明:如果侵犯了您的权益,请联系站长(1277306191@qq.com),我们会及时删除侵权内容,谢谢合作!

    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有账号?立即注册

    ×

    最新评论

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

    快速回复 返回顶部 返回列表