您的位置:首页 > 其它

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

2014-05-25 16:43 316 查看
构建文件入门[b][b][b][b][b]—[/b][/b]ant入门指南(2)[/b][/b][/b]

上一篇的教程《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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: