全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

微信小程序 Template详解及简单实例

微信小程序 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模板传递数据的方式总结  # 可以使用  # 则需  # 的是  # 都是  # 就会  # 文档  # 多个  # 而在  # 要在  # 要注意  # 希望能  # 并将  # 要用  # 要先  # 谢谢大家  # 中都  # 命名为  # 则会  # 即在  # 在同一个 


相关文章: 如何用好域名打造高点击率的自主建站?  北京制作网站的公司,北京铁路集团官方网站?  陕西网站制作公司有哪些,陕西凌云电器有限公司官网?  建站VPS能否同时实现高效与安全翻墙?  企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?  北京网站制作网页,网站升级改版需要多久?  音响网站制作视频教程,隆霸音响官方网站?  建站主机助手选型指南:2025年热门推荐与高效部署技巧  电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?  创业网站制作流程,创业网站可靠吗?  教程网站设计制作软件,怎么创建自己的一个网站?  网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?  外贸公司网站制作,外贸网站建设一般有哪些步骤?  长沙做网站要多少钱,长沙国安网络怎么样?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  济南网站建设制作公司,室内设计网站一般都有哪些功能?  如何用PHP工具快速搭建高效网站?  如何在腾讯云免费申请建站?  ,南京靠谱的征婚网站?  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  开源网站制作软件,开源网站什么意思?  定制建站如何定义?其核心优势是什么?  如何在建站主机中优化服务器配置?  制作农业网站的软件,比较好的农业网站推荐一下?  如何基于云服务器快速搭建网站及云盘系统?  建站之星好吗?新手能否轻松上手建站?  成都响应式网站开发,dw怎么把手机适应页面变成网页?  北京网站制作的公司有哪些,北京白云观官方网站?  如何在Windows虚拟主机上快速搭建网站?  如何用PHP快速搭建CMS系统?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  网站制作培训多少钱一个月,网站优化seo培训课程有哪些?  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  网站制作难吗安全吗,做一个网站需要多久时间?  官网建站费用明细查询_企业建站套餐价格及收费标准指南  网站制作大概多少钱一个,做一个平台网站大概多少钱?  建站之星如何修改网站生成路径?  如何在Golang中指定模块版本_使用go.mod控制版本号    建站org新手必看:2024最新搭建流程与模板选择技巧  建站之星安装模板失败:服务器环境不兼容?  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  如何用搬瓦工VPS快速搭建个人网站?  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  建站之星如何实现网站加密操作?  建站之星后台管理如何实现高效配置?  安徽网站建设与外贸建站服务专业定制方案  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  测试制作网站有哪些,测试性取向的权威测试或者网站?  香港服务器网站卡顿?如何解决网络延迟与负载问题? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。