微信小程序 template 模板标签接受对象或数组作为 data 参数 - 新闻资讯 - 云南小程序开发|云南软件开发|云南网站建设-昆明葵宇信息科技有限公司

159-8711-8523

云南网建设/小程序开发/软件开发

知识

不管是网站,软件还是小程序,都要直接或间接能为您产生价值,我们在追求其视觉表现的同时,更侧重于功能的便捷,营销的便利,运营的高效,让网站成为营销工具,让软件能切实提升企业内部管理水平和效率。优秀的程序为后期升级提供便捷的支持!

您当前位置>首页 » 新闻资讯 » 小程序相关 >

微信小程序 template 模板标签接受对象或数组作为 data 参数

发表时间:2021-3-31

发布人:葵宇科技

浏览次数:63

官网案例是直接用对象扩展运算符传递一些简单数据;

实际项目中,我需要传递一个数组,该数组的每一项都是一个对象,来实现一个比较复杂一点的模板功能;

最初的解决方案是套用官网的案例在wxml中使用循环,把每次循环的item也就是数组项作为参数传递到模板中,这就跟官网案例很相似;

但是这样做的一个问题就是代码还是感觉有点臃肿,本身作为模板最终的渲染逻辑应该是包含整个循环在内的,现在却把循环放到了代码中。这样用模板的意义就基本上没有了,优势也不存在了;

实例代码:

<!-- tmpl模板代码 -->
<template name="asd">
  <text>{{name}}</text>
</template>

<!-- 主题代码 -->
<block wx:for="{{item.data.singer}}">
  <block wx:if="{{index > 0}}"> / </block>
  <template is="asd" data="{{...item}}" />
</block>

经过思考,发现可以这样来实现;

<!-- tmpl模板代码 -->
<template name="abc">
  <block wx:for="{{array}}">
    <text><block wx:if="{{index > 0}}"> / </block>{{item.name}}</text>
  </block>
</template>

<!-- 主题代码 -->
<template is="abc" data="{{array: item.data.singer}}" />

嗯,看起来确实简洁很多了呢!!!

如果还有什么不明白的可以参考我的案例代码 地址 中的 /pages/album/index.wxml 页面。

相关案例查看更多