wxml提供两种文件引用方式import
和include
。
import
可以在该文件中使用目标文件定义的template
,如:
在item.wxml中定义了一个叫item
的template
:
<!-- item.wxml -->
<template name="item">
<text>{{text}}</text>
</template>
在index.wxml中引用了item.wxml,就可以使用item
模板:
<import src="item.wxml"/>
<template is="item" data="{{text: 'forbar'}}"/>
import有作用域的概念,即只会import目标文件中定义的template,而不会import目标文件import的template。
如:c import b,b import a,在c中可以使用b定义的template
,在b中可以使用a定义的template
,但是c不能使用a定义的template
。
<!-- a.wxml -->
<template name="a">
<text> a template </text>
</template>
<!-- b.wxml -->
<import src="a.wxml"/>
<template name="b">
<text> b template </text>
</template>
<!-- c.wxml -->
<import src="b.wxml"/>
<template is="a"/> <!-- error! can not use tempalte when not import a. -->
<template is="b"/>
include
可以将目标文件除了<template/>
的整个代码引入,相当于是拷贝到include
位置,如:
<!-- index.wxml -->
<include src="header.wxml"/>
<view> body </view>
<include src="footer.wxml"/>
<!-- header.wxml -->
<view> header </view>
<!-- footer.wxml -->
<view> footer </view>