构建文件入门—ant入门指南(2)

构建文件入门ant入门指南(2)


上一篇的教程《ant入门指南—web前端开发七武器(1)》明河主要讲解了ant的安装,以及贴出了一个简单的demo,接下来我们来看下demo中的build.xml(构建文件)的含义。

1.什么是构建文件?

构建文件是ant执行工程构建的入门文件,构建的所有任务都必须只能写在构建文件内,构建文件必须是符合标准的xml文件,默认的构建文件为build.xml,当你键入“ant”命名执行时,默认执行build.xml

关键点说明

  • 第一行为xml声明,必须存在;
  • 有且仅有一个project根标签;
  • default属性执行默认目标;
  • target(任务目标);
  • task:任务,是构建文件的最小执行单位,是具体干活的标签;
  • property:特性,或理解为属性。

2.新的demo代码

改变下上一篇的demo,增加点复杂点:创建一个src目录,将合并后的文件放在src目录下,并在合并后的文件内顶部添加一行自定义的合并注释。
新的demo中的build.xml:

<?xml version="1.0" standalone="yes"?>
<project default="build" name="refund">
    <property value="//合并自a.js和b.js" name="concat.note"></property>
    <target name="build">
        <echo>生成src目录</echo>
        <mkdir dir="src"></mkdir>
        <echo>开始合并文件</echo>
        <concat destfile="src/a_b.js">
            <header trimleading="yes">
                ${concat.note}
            </header>
            <path path="a.js"></path>
            <path path="b.js"></path>
        </concat>
    </target>
</project>



在“CMD”界面运行“ant”命令,结果如下:(请确保你的demo中有a.js和b.js)

成功运行后你就会发现生成了一个src目录,目录下有个a_b.js文件,文件的第一行注释是//合并自a.js和b.js,完全符合我们构建要求!
这个demo的代码会比上一篇教程复杂了不少,明河来逐个说明下。

property标签

property标签为特性标签,你可以理解为编程语言中的属性或者变量,它起到的作用和变量是类似的,赋值后的property,可以在之后的目标任务内方便的引用。
property有二种数据元素:

  • 以名—值对出现的简单数据定义形式,比如demo中的;
  • dataType复杂数据元素,比如fileset,日后会讲解到。

如何引用property呢?
非常简单,在你需要引用的地方使用${property名}即可,比如demo中的${concat.note}。
property的location属性
property除了value属性外,还有个location属性,起到的作用类似,区别是location属性用来保存路径,location带了路径转换功能,会将路径转成绝对路径,如果你的路径是/,它会自动转换成\,这个属性日后会经常用到。比如下面的代码:

<?xml version="1.0" standalone="yes"?>
<project default="build" name="refund">
    <property location="d:/ant-demo/" name="refund.dir"></property>
    <property location="../" name="refund.dir2"></property>
    <target name="build">
        <echo>${refund.dir}</echo>
        <echo>${refund.dir2}</echo>
    </target>
</project>



看看输出结果,留意明河取的是代码片段,请根据实际情况做下修改。

target标签

target标签非常的重要,“目标”标签可以理解为一系列任务标签的容器,是对任务的隐式说明,构建文件允许出现多个target,明河的建议是使用更细的target,比如demo中的代码可以修改为:

<?xml version="1.0" standalone="yes"?>
<project default="build" name="refund">
    <property value="//合并自a.js和b.js" name="concat.note"></property>
    <target name="mkdir">
        <echo>生成src目录</echo>
        <mkdir dir="src">
        </mkdir>
    </target>
    <target name="concat">
        <echo>开始合并文件</echo>
        <concat destfile="src/a_b.js">
            <header trimleading="yes">
                ${concat.note}
            </header>
            <path path="a.js"></path>
            <path path="b.js"></path>
        </concat>
    </target>
    <target depends="mkdir,concat" name="build"></target>
</project>



这里明河将一个target拆成了多个target,留意属性depends。
depends用于处理目标依赖,比如这里“build”依赖于“mkdir”和“concat”目标,那么ant会优先执行“mkdir”和“concat”然后才执行“build”。这种依赖机制是ant非常重要的处理模式!体现出ant的灵活性!

task任务标签

任务是ant构建文件的最小构建块,是构建的实施者,demo中的echo、concat都是任务标签,那么ant能完成多少个任务呢,或者说ant有多少构建功能呢?看了这个任务清单,我想你可以体会到ant究竟有多强大!
明河不会对所有的任务标签进行讲解,只讲解前端常用的几个关键任务标签,今天先到这里,下一篇教程将详细讲解concat、mkdir、copy等标签用法。


转自:www.36ria.com/4436

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值