小程序?qū)W習筆記3-模板template、列表和頁面?zhèn)髦?/h1>

今天練習的兩個頁面有相同的模塊责鳍,決定用模板來實現(xiàn)代碼的復(fù)用碾褂。

先來看兩個頁面,首頁和瀏覽記錄頁列表項格式完全相同历葛,所以正塌,抽取這個列表項作為模板,網(wǎng)上也有同學抽取整個列表作為模板恤溶,做法差不多乓诽,我沒有試,還是習慣抽取一個小模塊咒程,這樣靈活度更高一些鸠天。

抽取模板

模板介紹

WXML提供模板(template),可以在模板中定義代碼片段帐姻,然后在不同的地方調(diào)用稠集。

定義模板
使用 name 屬性,作為模板的名字饥瓷。然后在<template/>內(nèi)定義代碼片段剥纷,如:

<!--
  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'
    }
  }
})

模板教程見《微信官方學習文檔-模板》

模板實現(xiàn)步驟

  1. 創(chuàng)建一個模板文件夾template棺克,在文件夾下創(chuàng)建模板文件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>海淀中關(guān)村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. 關(guān)于模板樣式,我寫的比較亂有一部分直接寫在模板文件里娜谊,另一部分寫在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"/>

在響應(yīng)的位置使用模板創(chuàng)建列表項:

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

此時的頁面效果


首頁使用模板

模板數(shù)據(jù)綁定和列表實現(xiàn)

上面3步實現(xiàn)模板的使用,現(xiàn)在的數(shù)據(jù)是在模板中寫死的抹剩,而且列表中只有一條列表項撑帖。所謂模板,數(shù)據(jù)肯定是靈活的澳眷,下一步修改一下創(chuàng)建的模板來實現(xiàn)一個列表并綁定數(shù)據(jù)胡嘿。

  1. 在頁面js中造一個列表的假數(shù)據(jù):
houseList:[
      {
        id:'1001',
        title:'海淀區(qū)學院南路68號',
        leaseType:'整租',
        houseType:'三室一廳',
        price:'9800',
        image:'../../images/home/home_1.png'
      },
      {
        id: '1002',
        title: '海淀區(qū)中關(guān)村南大街17號',
        leaseType: '整租',
        houseType: '一室一廳',
        price: '5500',
        image: '../../images/home/home_2.png'
      },
      {
        id: '1003',
        title: '豐臺區(qū)馬家堡街道嘉園二里',
        leaseType: '合租',
        houseType: '三室一廳',
        price: '2900',
        image: '../../images/home/home_1.png'
      },
  1. 修改houseItem.wxml文件,將頁面寫死的數(shù)據(jù)替換成活的钳踊,由于需要點擊跳轉(zhuǎn)衷敌,頁面元素也修改了一下勿侯,外層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. 模板調(diào)用修改使用for循環(huán)遍歷列表數(shù)據(jù),進行模板數(shù)據(jù)綁定缴罗。
<view>
  <block wx:for="{{houseList}}">
    <template is="houseItem" data="{{...item}}"></template>
  </block>
</view>
  1. 實現(xiàn)效果展示
最終效果.png

頁面?zhèn)髦?/h1>
  1. 上面例子中將id值傳給了下個頁面logs助琐。通過直接在url后面拼接參數(shù)是最簡單的直接傳值方式。
<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>上個頁面?zhèn)鬟^來的id:{{id}}</text>
  1. 編譯一下舌界,點擊列表項跳轉(zhuǎn):


    image.png

后記

模板掘譬、列表、傳值等的使用都非常簡單呻拌,開發(fā)起來也方便快捷葱轩,我在開發(fā)過程中浪費時間最多的還是頁面樣式。
例子中用到的樣式邊框藐握,居中靴拱,各種排列讓我真的讓我費勁了心思。到最后發(fā)現(xiàn)和UI還有一些出入趾娃,比如列表項圖片背景和文字背景是不同的缭嫡,但是發(fā)現(xiàn)的時候已經(jīng)晚了缔御,懶得再改了抬闷,幸好是聯(lián)系不是實際開發(fā),還是要繼續(xù)熟練各種樣式~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者

  • 序言:七十年代末耕突,一起剝皮案震驚了整個濱河市笤成,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌眷茁,老刑警劉巖炕泳,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異上祈,居然都是意外死亡培遵,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進店門登刺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來籽腕,“玉大人,你說我怎么就攤上這事纸俭』屎模” “怎么了?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵揍很,是天一觀的道長郎楼。 經(jīng)常有香客問我万伤,道長,這世上最難降的妖魔是什么呜袁? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任敌买,我火速辦了婚禮,結(jié)果婚禮上阶界,老公的妹妹穿的比我還像新娘放妈。我一直安慰自己,他們只是感情好荐操,可當我...
    茶點故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布芜抒。 她就那樣靜靜地躺著,像睡著了一般托启。 火紅的嫁衣襯著肌膚如雪宅倒。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天屯耸,我揣著相機與錄音慕趴,去河邊找鬼泛啸。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的尾序。 我是一名探鬼主播,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼氯析,長吁一口氣:“原來是場噩夢啊……” “哼登失!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起塔逃,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤讯壶,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后湾盗,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體伏蚊,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年格粪,在試婚紗的時候發(fā)現(xiàn)自己被綠了躏吊。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,018評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡帐萎,死狀恐怖比伏,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情吓肋,我是刑警寧澤凳怨,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響肤舞,放射性物質(zhì)發(fā)生泄漏紫新。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一李剖、第九天 我趴在偏房一處隱蔽的房頂上張望芒率。 院中可真熱鬧,春花似錦篙顺、人聲如沸偶芍。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽匪蟀。三九已至,卻和暖如春宰僧,著一層夾襖步出監(jiān)牢的瞬間材彪,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工琴儿, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留段化,地道東北人。 一個月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓造成,卻偏偏與公主長得像显熏,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子晒屎,可洞房花燭夜當晚...
    茶點故事閱讀 42,762評論 2 345