tempalte的使用

96
神秘者007
2017.11.19 14:34 字数 532

微信小程序 Template

模板

WXML提供模板(Template),可以在模板中定义代码片段,然后在不同的地方使用。可以保证格式以及数据的相同。

1-定义模板

使用``标签定义模板,并将模板名称命名为tempName,赋值给属性name。在标签内部,定义模板结构。如下:

index: int

msg: string

time: string

{{index}}: {{msg}}

Time: {{time}}

2-使用模板

使用

此时页面上就会重复显示三次相同的信息。

data中的数据,来源于js文件,如下:

Page({

data: {

item: {

index: 0,

msg:'this is a template',

time:'2016-09-15'

}

}

})

3-is属性

is属性不仅可以静态的指向渲染的模板,也可以使用Mustache语法,来动态决定具体需要渲染哪个模板。如下:

// templates

odd

even

// is属性使用Mustache语法动态渲染template

如上代码,则会在页面中根据条件来显示odd 或是 even

4-模板的引用

如上都是在同一个wxml文件中定义和引用模板,而模板的定义和引用是可以分开的。即在一个文件中定义模板,而在其他一个或多个文件wxml文件中都可以使用定义好的模板。

从外部文件中引用模板,使用import src="templateUrl" />标签。同样使用is属性来指向要引用的标签。

如目录如下:

|--index

|--index.js

|--index.json

|--index.wxml

|--index.wxss

|--template

|--template.js

|--template.json

|--template.wxml

|--template.wxss

要在index.wxml中使用template中定义的模板,则需要先在index中利用import来导入该模板:

// 使用的是自己js文件中的数据

要注意import作用域,其仅仅引用目标文件中template。如:C import B,B import A,在C中可以使用B定义的template,在B中可以使用A定义的template,但是C不能使用A定义的template。

微信小程序
Web note ad 1