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

发布时间 - 2026-01-10 22:20:12    点击率:

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


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  夸克浏览器网页跳转延迟怎么办 夸克浏览器跳转优化  百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  Laravel如何使用Service Provider服务提供者_Laravel依赖注入与容器绑定【深度】  Laravel的.env文件有什么用_Laravel环境变量配置与管理详解  Laravel怎么使用Intervention Image库处理图片上传和缩放  实例解析angularjs的filter过滤器  Laravel如何创建自定义中间件?(Middleware代码示例)  C++时间戳转换成日期时间的步骤和示例代码  Android实现代码画虚线边框背景效果  大型企业网站制作流程,做网站需要注册公司吗?  如何在云服务器上快速搭建个人网站?  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  Laravel如何实现API版本控制_Laravel版本化API设计方案  安克发布新款氮化镓充电宝:体积缩小 30%,支持 200W 输出  奇安信“盘古石”团队突破 iOS 26.1 提权  如何在万网ECS上快速搭建专属网站?  实例解析Array和String方法  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱动更新修复【详解】  Laravel如何使用Service Container和依赖注入?(代码示例)  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  如何撰写建站申请书?关键要点有哪些?  iOS发送验证码倒计时应用  laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法  高端建站三要素:定制模板、企业官网与响应式设计优化  开心动漫网站制作软件下载,十分开心动画为何停播?  如何为不同团队 ID 动态生成多个独立按钮  Laravel如何使用Gate和Policy进行授权?(权限控制)  如何快速搭建二级域名独立网站?  Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南  JS经典正则表达式笔试题汇总  浅谈javascript alert和confirm的美化  如何在搬瓦工VPS快速搭建网站?  如何在宝塔面板创建新站点?  音响网站制作视频教程,隆霸音响官方网站?  WordPress 子目录安装中正确处理脚本路径的完整指南  Python图片处理进阶教程_Pillow滤镜与图像增强  Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  Swift开发中switch语句值绑定模式  Laravel如何编写单元测试和功能测试?(PHPUnit示例)  绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信  Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能  Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】  在线制作视频网站免费,都有哪些好的动漫网站?  Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控