日期:2014-05-16  浏览次数:20420 次

yuicompressor-2.4.2.jar 和 YUIAnt-zh_CN.jar ANT 压缩JS文件,提高js运行速度

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

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

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

3、俩个文件的附件

下载地址在我的资源中

http://download.csdn.net/detail/dracotianlong/5033927

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>