微信小程序视图层WXML_小程序引用
微信小程序WXML提供两种文件引用方式import
和include
。
import
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有作用域的概念,即只会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
微信小程序
的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>