微信小程序 Template

模板
WXML提供模板(Template),可以在模板中定义代码片段,然后在不同的地方使用。可以保证格式以及数据的相同。
1-定义模板
使用`<template name="tempName"></template>`标签定义模板,并将模板名称命名为tempName,赋值给属性name。在标签内部,定义模板结构。如下:
<!-- template.wxml -->
<!--
index: int
msg: string
time: string
-->
<template name="msgItem">
<view>
<text> {{index}}: {{msg}} </text>
<text> Time: {{time}} </text>
</view>
</template>
2-使用模板
使用<template is="tempName" />标签,在需要使用模板的地方。如果要用到js文件中的数据,则需要添加data属性。如下:
<!-- template.wxml -->
<template is="msgItem" data="{{...item}}"/>
<template is="msgItem" data="{{...item}}"/>
<template is="msgItem" data="{{...item}}"/>
此时在页面上就会重复显示三次相同的信息。
data中的数据,来源于js文件,如下:
<!-- template.js -->
Page({
data: {
item: {
index: 0,
msg: 'this is a template',
time: '2016-09-15'
}
}
})
3-is属性
is属性不仅可以静态的指向渲染的模板,也可以使用Mustache语法,来动态决定具体需要渲染哪个模板。如下:
<!-- template.wxml -->
// templates
<template name="odd">
<view> odd </view>
</template>
<template name="odd">
<view> even </view>
</template>
// is属性使用Mustache语法动态渲染template
<block wx:for="{{[1, 2, 3, 4,5]}}">
<template is="{{item % 2 == 0 ? 'even' : 'odd'}}" />
</block>
如上代码,则会在页面中根据条件来显示odd 或是 even
4-模板的引用
如上都是在同一个wxml文件中定义和引用模板,而模板的定义和引用是可以分开的。即在一个文件中定义模板,而在其他一个或多个文件wxml文件中都可以使用定义好的模板。
从外部文件中引用模板,使用import src="templateUrl" />标签。同样使用is属性来指向要引用的标签。
如目录如下:
-pages
|--index
|--index.js
|--index.json
|--index.wxml
|--index.wxss
|--template
|--template.js
|--template.json
|--template.wxml
|--template.wxss
要在index.wxml中使用template中定义的模板,则需要先在index中利用import来导入该模板:
<!-- index.wxml -->
<import src="../template/template.wxml"
<template is="msgItem" data={{...indexData}}
// 使用的是自己js文件中的数据
要注意import作用域,其仅仅引用目标文件中template。如:C import B,B import A,在C中可以使用B定义的template,在B中可以使用A定义的template,但是C不能使用A定义的template。
参考
微信小程序文档-框架-视图层-WXML-模板
微信小程序文档-框架-视图层-WXML-引用
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# 微信小程序
# Template
# Template详解
# Template实例
# 微信小程序 template模板详解及实例
# 微信小程序 template模板详解及实例代码
# 微信小程序视图template模板引用的实例详解
# 微信小程序template模板实例详解
# 微信小程序-详解微信登陆、微信支付、模板消息
# 微信小程序 跳转传递数据的实例
# 微信小程序使用navigateTo数据传递的实例
# 微信小程序 页面跳转和数据传递实例详解
# 微信小程序实现给嵌套template模板传递数据的方式总结
# 可以使用
# 则需
# 的是
# 都是
# 就会
# 文档
# 多个
# 而在
# 要在
# 要注意
# 希望能
# 并将
# 要用
# 要先
# 谢谢大家
# 中都
# 命名为
# 则会
# 即在
# 在同一个
相关文章:
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
如何快速启动建站代理加盟业务?
建站OpenVZ教程与优化策略:配置指南与性能提升
如何在阿里云虚拟服务器快速搭建网站?
如何通过WDCP绑定主域名及创建子域名站点?
实现点击下箭头变上箭头来回切换的两种方法【推荐】
如何高效完成自助建站业务培训?
如何快速生成专业多端适配建站电话?
如何在云指建站中生成FTP站点?
成都网站制作公司哪家好,四川省职工服务网是做什么用?
定制建站模板如何实现SEO优化与智能系统配置?18字教程
python的本地网站制作,如何创建本地站点?
独立制作一个网站多少钱,建立网站需要花多少钱?
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
ui设计制作网站有哪些,手机UI设计网址吗?
在线制作视频的网站有哪些,电脑如何制作视频短片?
html制作网站的步骤有哪些,iapp如何添加网页?
建站之星如何通过成品分离优化网站效率?
如何解决ASP生成WAP建站中文乱码问题?
c# 在ASP.NET Core中管理和取消后台任务
如何在宝塔面板创建新站点?
网站制作培训多少钱一个月,网站优化seo培训课程有哪些?
网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
为什么Go需要go mod文件_Go go mod文件作用说明
深圳网站制作培训,深圳哪些招聘网站比较好?
百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
如何设计高效校园网站?
宝塔面板如何快速创建新站点?
如何制作一个表白网站视频,关于勇敢表白的小标题?
建站之星×万网:智能建站系统+自助建站平台一键生成
网站制作难吗安全吗,做一个网站需要多久时间?
,南京靠谱的征婚网站?
家具网站制作软件,家具厂怎么跑业务?
c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】
Python文件管理规范_工程实践说明【指导】
建站主机服务器选型指南与性能优化方案解析
如何在宝塔面板中创建新站点?
如何在建站之星网店版论坛获取技术支持?
制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?
如何在Windows环境下新建FTP站点并设置权限?
制作国外网站的软件,国外有哪些比较优质的网站推荐?
长沙企业网站制作哪家好,长沙水业集团官方网站?
如何在局域网内绑定自建网站域名?
制作网站外包平台,自动化接单网站有哪些?
SQL查询语句优化的实用方法总结
常州自助建站费用包含哪些项目?
建站之星如何快速解决建站难题?
测试制作网站有哪些,测试性取向的权威测试或者网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。