小程序学习笔记3-模板template、列表和页面传值

今天练习的两个页面有相同的模块,决定用模板来实现代码的复用。

先来看两个页面,首页和浏览记录页列表项格式完全相同,所以,抽取这个列表项作为模板,网上也有同学抽取整个列表作为模板,做法差不多,我没有试,还是习惯抽取一个小模块,这样灵活度更高一些。

抽取模板

模板介绍

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

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

<!--
  index: int
  msg: string
  time: string
-->
<template name="msgItem">
  <view>
    <text> {{index}}: {{msg}} </text>
    <text> Time: {{time}} </text>
  </view>
</template>

使用模板
使用 is 属性,声明需要的使用的模板,然后将模板所需要的 data 传入,如:

<template is="msgItem" data="{{...item}}"/>
Page({
  data: {
    item: {
      index: 0,
      msg: 'this is a template',
      time: '2016-09-15'
    }
  }
})

模板教程见《微信官方学习文档-模板》

模板实现步骤

  1. 创建一个模板文件夹template,在文件夹下创建模板文件houseItem.wxml。

houseItem.wxml代码:

<template name="houseItem">
  <view class='houseItem-bg' style='display: flex;flex-direction: column; align-items: center; margin:10px;padding:5px;border-radius: 5px;background-color: white;'>
    <view class='houseItem-img'>
      <image src='../../images/home/home_1.png' mode="aspectFill"></image>
    </view>
    <view class='houseItem-text'>
      <view class='houseItem-text-l' style='border-right: 1px solid #D9D9D9;padding-right:10px'>
        <text>海淀中关村17号  15栋4单元高层</text>
        <view>
          <text style='border: 1px solid #1AAD00;padding:2px 10px;color:#1AAD00;font-size:14px'>整租</text>
          <text style='border: 1px solid #FF7033;padding:2px 10px;color:#FF7033;font-size:14px;margin-left:15px;'>三室一厅</text>
        </view>
      </view>
      <view class='houseItem-text-r'>
        <text style='color:red;font-size:20px'>¥13500</text>
      </view>
    </view>
  </view>
</template>
  1. 关于模板样式,我写的比较乱有一部分直接写在模板文件里,另一部分写在app.wxss中了。
    还可以单独写一个wxss文件来写样式,但是注意,一定要在模板使用界面引用wxss样式文件。
    app.wxss模板样式代码:
/*houseItem 模板样式*/
.houseItem-img {
  width: 100%;
}
.houseItem-img image {
  width: 100%;
}
.houseItem-text {
  display: flex;
  flex-direction: row;
  width: 100%; 
  margin: 10px;
  background-color: white;
}
.houseItem-text-l {
  width: 68%;
}
.houseItem-text-r {
  margin: auto;
}

  1. 引用模板

在需要使用模板的开头先引用模板文件

<!-- 声明需要使用的模板文件 -->
<import src ="../../template/houseItem.wxml"/>

在响应的位置使用模板创建列表项:

<view>
  <template is="houseItem"/> 
</view>

此时的页面效果


首页使用模板

模板数据绑定和列表实现

上面3步实现模板的使用,现在的数据是在模板中写死的,而且列表中只有一条列表项。所谓模板,数据肯定是灵活的,下一步修改一下创建的模板来实现一个列表并绑定数据。

  1. 在页面js中造一个列表的假数据:
houseList:[
      {
        id:'1001',
        title:'海淀区学院南路68号',
        leaseType:'整租',
        houseType:'三室一厅',
        price:'9800',
        image:'../../images/home/home_1.png'
      },
      {
        id: '1002',
        title: '海淀区中关村南大街17号',
        leaseType: '整租',
        houseType: '一室一厅',
        price: '5500',
        image: '../../images/home/home_2.png'
      },
      {
        id: '1003',
        title: '丰台区马家堡街道嘉园二里',
        leaseType: '合租',
        houseType: '三室一厅',
        price: '2900',
        image: '../../images/home/home_1.png'
      },
  1. 修改houseItem.wxml文件,将页面写死的数据替换成活的,由于需要点击跳转,页面元素也修改了一下,外层view改为navigator.
    修改后的houseItem.wxml代码
<template name="houseItem">
  <navigator url='../logs/logs?id={{id}}' class='houseItem-bg' style='display: flex;flex-direction: column; align-items: center; margin:10px;padding:5px;border-radius: 5px;background-color: white;'>
    <view class='houseItem-img'>
      <image src='{{image}}' mode="aspectFill"></image>
    </view>
    <view class='houseItem-text'>
      <view class='houseItem-text-l' style='border-right: 1px solid #D9D9D9;padding-right:10px'>
        <text>{{title}}</text>
        <view>
          <text style='border: 1px solid #1AAD00;padding:2px 10px;color:#1AAD00;font-size:14px'>{{leaseType}}</text>
          <text style='border: 1px solid #FF7033;padding:2px 10px;color:#FF7033;font-size:14px;margin-left:15px;'>{{houseType}}</text>
        </view>
      </view>
      <view class='houseItem-text-r'>
        <text style='color:red;font-size:20px'>¥{{price}}</text>
      </view>
    </view>
  </navigator>
</template>
  1. 模板调用修改使用for循环遍历列表数据,进行模板数据绑定。
<view>
  <block wx:for="{{houseList}}">
    <template is="houseItem" data="{{...item}}"></template>
  </block>
</view>
  1. 实现效果展示
最终效果.png

页面传值

  1. 上面例子中将id值传给了下个页面logs。通过直接在url后面拼接参数是最简单的直接传值方式。
<navigator url='../logs/logs?id={{id}}'/>
  1. 在下一个页面logs.js的onLoad方法中接收id值。
    logs.js代码:
onLoad: function (options) {
    this.setData({
      id:options.id,
      })
    })
  1. 在logs.wxml添加元素,展示传过来的值。
<text>上个页面传过来的id:{{id}}</text>
  1. 编译一下,点击列表项跳转:


    image.png

后记

模板、列表、传值等的使用都非常简单,开发起来也方便快捷,我在开发过程中浪费时间最多的还是页面样式。
例子中用到的样式边框,居中,各种排列让我真的让我费劲了心思。到最后发现和UI还有一些出入,比如列表项图片背景和文字背景是不同的,但是发现的时候已经晚了,懒得再改了,幸好是联系不是实际开发,还是要继续熟练各种样式~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335