• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

微信小程序(十二)实战——小程序模板template的使用,以及传递集合数据 ...

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

如下图,我们经常做这样的列表页,课程搜索结果页和课程列表页结构是完全一样的,非常适合使用模板来完成页面搭建。

这样我们就不用写那些重复的代码了,而且修改界面的时候也只需要改动模板一个地方

WXML提供模板(template),可以在模板中定义代码片段,然后在不同的地方调用。


一、定义模板

1、新建一个template文件夹用来管理项目中所有的模板; 

"pages/template/personCourseTmp",

2、新建一个personCourseTmp.wxml文件来定义模板; 

3、使用name属性,作为模板的名字。然后在<template/>内定义代码片段。

<template name="personCourseItemTmp">
</template>

4.那我们开始实现吧,建模板2个文件

1.personCourseTmp.wxml

<template name="personCourseItemTmp">
<!-- 显示 -->
<view wx:if="{{mentor_image_uri==null}}">
<image class="widget_arrow" src="http://dev.cfo-mentor.com/menter/public/assets/images/avatar_default.png" mode="aspectFill">
</image>
</view>
<view wx:else>
<image class="widget_arrow" src="{{mentor_image_uri}}" mode="aspectFill"></image>
</view>
<view class='info'>姓名:{{mentor_name}}</view>
<view class='info'>职位:{{career}}</view>
<view class='info'>公司:{{company_name}}</view>
<view class='info'>地区:{{address}}</view>
<view class='info'>擅长:{{mentor_skills}}</view>
<navigator url='../../pages/info/info?user_id={{user_id}}'>详情</navigator>
<view class='hr'></view>
</template>

2.样式文件personCourseTmp.wxss


.name{
text-align: center;
}
.widget_arrow{
margin-top: 20px;
height: 200px;
width: 200px;
margin-left: 25%;
}
.info{
font-size:14px
}
.info_border{
height: 200px;
width: 200px;
border: 8px solid red;
}
navigator{
margin: 0 auto;
height: 40px;
width: 90%;
margin-top: 20px;
margin-bottom: 20px;
background-color: green;
line-height: 40px;
text-align: center;
}
.hr{
height: 0;
width: 100%;
border: 1px solid green;
}

那我们如何在页面上使用呢,引入样式文件和视图文件

比如我们要在.wxss上面引入样式文件

@import "../template/personCourseTmp.wxss";

只需要在.wxss里面加入上面的代码

我们要在.wxml上面引入视图文件

<import src="../template/personCourseTmp.wxml" />


<block wx:for="{{message}}" wx:key="id">
<template is="personCourseItemTmp" data="{{...item}}"></template>
</block>

<template is=''  "    data=" "></template> 

 此时的is用来进行判断  data是要传入模板中的数据...eg   ...(spread运算符) 

传数据时item前面加三个点... 模板里面就不需要写item了。

注意

import作用域,其仅仅引用目标文件中template。如:

C import B                              B import A

C中可以使用B定义的template,在B中可以使用A定义的template,但是C不能使用A定义的template。



鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
javaweb闲暇小程序之抽签程序发布时间:2022-07-18
下一篇:
微信小程序ES6——字符串模板发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap