JavaScript 组件之旅(三):用 Ant 构建组件


Posted in Javascript onOctober 28, 2009

听起来是不是很惬意?Let's go! 我们出发啦~

这期,我们会使用 Ant 将上期编写、整理的代码文件按指定的先后顺序合并成单一的源文件,然后压缩这个文件。这是构建 JavaScript 项目的基本步骤。Ant 是 Apache 的一个顶级开源项目,网上对它的介绍和安装,已经有很多文章,这里就不再赘述了。在构建之前,我们先来看看已有的文件布局:

smart-queue // 组件的根目录
  +--- src // JavaScript源文件目录
    +--- lang.js // 前文提到的“外部文件”
    +--- smart-queue.js // Smart Queue 主文件

现在,我们要让它“丰满”起来:

  • 组件根目录下添加:
    • README: 介绍 Smart Queue 组件
    • LICENSE: 组件的授权信息
    • build.xml: Ant 使用的配置文件
  • 组件根目录下添加 lib 子目录:存放构建过程中需要使用的外部程序和库文件
    • lib 子目录下添加 yuicompressor.jar: 我们用 YUI Compressor 压缩 JavaScript
  • 组件根目录下添加 test 子目录:存放测试组件所需的文件(下期介绍)
  • src 目录下添加 intro.js: 介绍组件的版本及说明信息

麻雀虽小,五脏俱全。现在 Smart Queue 看上去像是比较专业的 JavaScript 项目了:

smart-queue // 组件的根目录
  +--- lib // JavaScript外部程序和库文件目录
    +--- yuicompressor.jar // YUI Compressor
  +--- test // 测试文件目录
  +--- src // JavaScript源文件目录
    +--- intro.js // 介绍和版本信息
    +--- lang.js // 前文提到的“外部文件”
    +--- smart-queue.js // Smart Queue 主文件
  +--- README // 组件自述文件
  +--- LICENSE // 组件授权信息

我们计划将构建出来的文件存放到组件根目录下的 build 子目录,还要通过构建工具创建并销毁它。首次尝试构建前,建议先大概了解一下 Ant 的配置文件——build.xml 的结构:

<project name="MyProject" default="dist" basedir=".">
  <description>
    simple example build file
  </description>
 <!-- set global properties for this build -->
 <property name="src" location="src"/>
 <property name="build" location="build"/>
 <property name="dist" location="dist"/>

 <target name="init">
  <!-- Create the time stamp -->
  <tstamp/>
  <!-- Create the build directory structure used by compile -->
  <mkdir dir="${build}"/>
 </target>

 <target name="compile" depends="init"
    description="compile the source " >
  <!-- Compile the java code from ${src} into ${build} -->
  <javac srcdir="${src}" destdir="${build}"/>
 </target>

 <target name="clean"
    description="clean up" >
  <!-- Delete the ${build} and ${dist} directory trees -->
  <delete dir="${build}"/>
  <delete dir="${dist}"/>
 </target>
</project>

仔细观察一下,除了 name, description 这些名字都很容易理解外,其他可以看到的规律包括:

  • project 元素的 default 属性值对应某个 target 元素的 name 属性;
  • target 元素的 depends 属性值对应其他某些 target 元素的 name 属性;
  • ${somename} 可以引用 property 中定义的值。

下面我们开始写自己的 build.xml.

首先,配置项目的基本信息,以及相关目录名称,将要使用的编码等等:

<project name="Smart Queue" default="compress" basedir=".">
  <description>Build file for Ant</description>
  <property name="src" location="src" />
  <property name="build" location="build" />
  <property name="lib" location="lib"/>
  <property name="inputencoding" value="utf-8"/>
  <property name="outputencoding" value="gbk"/>

接着,定义一个用于初始化的 target, 它负责创建 build 子目录:

<target name="init">
    <mkdir dir="${build}"/>
  </target>

然后定义名为 concattarget, 负责将 src 里的 3 个 JavaScript 文件按先后顺序连接起来。运行它要先运行前面定义的 init:

<target name="concat" depends="init">
    <concat destfile="${build}/smart-queue.source.js" encoding="${inputencoding}" outputencoding="${outputencoding}">
      <filelist dir="${src}" files="intro.js, lang.js, smart-queue.js" />
    </concat>
  </target>

这样,就可以得到一个可以工作的 JavaScript 文件,下面的 target 负责压缩这个文件,显然它依赖于 concat, 也依赖于 init, 但是不必显式指定对 init 的依赖——Ant 能处理这种依赖关系。这里调用 YUI Compressor 并传入适当的参数:

<target name="compress" depends="concat">
    <java jar="${lib}/yuicompressor.jar" fork="true">
      <arg line="--type js --charset utf-8 -o ${build}/smart-queue.js ${build}/smart-queue.js"/>
    </java>
  </target>

大功告成,compress 处理后的文件就可以部署到生产系统上去了。最后我们做一下清理工作,使你在生成文件后还可以回到最初的状态:

<target name="clean">
    <delete dir="${build}"/>
  </target>

到此可以说基本的配置就写完了。怎么使用它呢?以命令行方式进入到组件根目录(或者说 build.xml 所在的目录),然后:

  • 运行 ant concat, 将得到 ./build/smart-queue.source.js
  • 运行 ant, 将选择 <project>default 引用的那个 target, 即 compress, 所以会得到 ./build 下的 smart-queue.source.js 和 smart-queue.js
  • 运行 ant clean, 将删除 ./build 目录,回到最初的状态

这些前提是你已经正确安装或者说设置好了 JDK 和 Ant, 如果有错误提示出来,则可能需要检查它们是否已准备妥当。

一路看下来,是不是觉得本期介绍的东西很简单?那是当然了,构建工具就应该简单易用,否则把大量的时间花在那上面岂非不值?工具的价值在于提升生产力,从而创造更多价值。

最后,你可以在这里查看 Ant 的帮助文档(里面有很多好玩的东东哦),也可以在这里查看本期完整的 build.xml 文件。

Javascript 相关文章推荐
非常不错的一个javascript 类
Nov 07 Javascript
在jQuery 1.5中使用deferred对象的代码(翻译)
Mar 10 Javascript
基于JavaScript 数据类型之Boolean类型分析介绍
Apr 19 Javascript
jquery 根据name名获取元素的value值
Feb 27 Javascript
js的各种排序算法实现(总结)
Jul 23 Javascript
javascript 面向对象实战思想分享
Sep 07 Javascript
使用Bootstrap + Vue.js实现表格的动态展示、新增和删除功能
Nov 27 Javascript
Vue精简版风格概述
Jan 30 Javascript
vue 组件的封装之基于axios的ajax请求方法
Aug 11 Javascript
JavaScript的查询机制LHS和RHS解析
Aug 16 Javascript
在vscode 中设置 vue模板内容的方法
Sep 02 Javascript
详解Vue3.0 + TypeScript + Vite初体验
Feb 22 Vue.js
JavaScript 组件之旅(二)编码实现和算法
Oct 28 #Javascript
JavaScript 组件之旅(一)分析和设计
Oct 28 #Javascript
js 数组实现一个类似ruby的迭代器
Oct 27 #Javascript
jquery 操作单选框,复选框,下拉列表实现代码
Oct 27 #Javascript
javascript获得CheckBoxList选中的数量
Oct 27 #Javascript
基于jQuery的日期选择控件
html 锁定页面(js遮罩层弹出div效果)
Oct 27 #Javascript
You might like
php在页面中调用fckeditor编辑器的方法
2011/06/10 PHP
curl实现站外采集的方法和技巧
2014/01/31 PHP
PHP中仿制 ecshop验证码实例
2017/01/06 PHP
PHP实现蛇形矩阵,回环矩阵及数字螺旋矩阵的方法分析
2017/05/29 PHP
IOS 开发之NSDictionary转换成JSON字符串
2017/08/14 PHP
Laravel 之url参数,获取路由参数的例子
2019/10/21 PHP
学习ExtJS(二) Button常用方法
2009/10/07 Javascript
javascript对select标签的控制(option选项/select)
2013/01/31 Javascript
js控制文本框输入的字符类型方法汇总
2015/06/19 Javascript
js仿微博实现统计字符和本地存储功能
2015/12/22 Javascript
超全面的javascript中变量命名规则
2017/02/09 Javascript
angularJS利用ng-repeat遍历二维数组的实例代码
2017/06/03 Javascript
原生JS实现的简单轮播图功能【适合新手】
2018/08/17 Javascript
详解javascript中的Error对象
2019/04/25 Javascript
layui-table获得当前行的上/下一行数据的例子
2019/09/24 Javascript
el-form 多层级表单的实现示例
2020/09/10 Javascript
Python的Django框架中使用SQLAlchemy操作数据库的教程
2016/06/02 Python
Python代码解决RenderView窗口not found问题
2016/08/28 Python
python安装cx_Oracle模块常见问题与解决方法
2017/02/21 Python
Python用sndhdr模块识别音频格式详解
2018/01/11 Python
Python3使用正则表达式爬取内涵段子示例
2018/04/22 Python
python实现周期方波信号频谱图
2018/07/21 Python
Python求均值,方差,标准差的实例
2019/06/29 Python
Python 正则表达式爬虫使用案例解析
2019/09/23 Python
python 有效的括号的实现代码示例
2019/11/11 Python
Python解析多帧dicom数据详解
2020/01/13 Python
Python实现捕获异常发生的文件和具体行数
2020/04/25 Python
解决django 向mysql中写入中文字符出错的问题
2020/05/18 Python
CSS3实现可关闭的下拉手风琴菜单效果
2015/08/31 HTML / CSS
生物制药毕业生自荐信
2013/10/16 职场文书
大学生精神文明先进个人事迹材料
2014/05/02 职场文书
2014年学前班工作总结
2014/12/08 职场文书
2015年求职自荐信范文
2015/03/04 职场文书
村级干部党员公开承诺事项
2015/05/04 职场文书
新学期新寄语,献给新生们!
2019/11/15 职场文书
python之json文件转xml文件案例讲解
2021/08/07 Python