微信小程序之左右佈局

本文以一個簡單的小例子,簡述在微信小程序開發中左右佈局功能的實現方式,主要涉及scroll-view ,列表數據綁定,及簡單樣式等內容,僅供學習分享使用。小程序

概述

在微信小程序開發中,左右分欄(左邊顯示分類,右邊顯示明細,而後進行聯動)是一種常見的佈局方式,多應用於點餐,冷飲店,外賣,以及其餘相似的商城。微信小程序

佈局分析

佈局分析圖示以下:數組

涉及知識點

  • scroll-view 可滾動視圖區域。使用豎向滾動時,須要給<scroll-view>一個固定高度,經過 WXSS 設置 height。組件屬性的長度單位默認爲px,2.4.0起支持傳入單位(rpx/px)。
  • scroll-y  是否容許縱向滾動,默認false。
  • scroll-into-view  值應爲某子元素id(id不能以數字開頭)。設置哪一個方向可滾動,則在哪一個方向滾動到該元素(動態更新該屬性的值,實現左右聯動)。
  • view 基礎控件。
  • hover-class   設置指定按下去的樣式類。當 hover-class="none" 時,沒有點擊態效果。
  • wx:for 在組件上使用 wx:for 控制屬性綁定一個數組,便可使用數組中各項的數據重複渲染該組件。默認數組的當前項的下標變量名默認爲 index,數組當前項的變量名默認爲 item。
  • bindtap='showItem' 綁定組件的單擊事件,不加括弧

示例效果圖

示例效果圖以下所示:微信

核心代碼

WXML代碼以下:佈局

 1 <!--pages/show/show.wxml-->
 2 <view class="show-info">
 3   <scroll-view class='left' scroll-y>
 4     <view class="jy-item" wx:for="{{jytype}}" wx:key="id" hover-class="jy-item-hover" wx:for-item="item" bindtap='showItem' data-id="{{item.id}}">
 5       <image src="{{item.url}}"></image>
 6       <label>{{item.name}}</label>
 7     </view>
 8   </scroll-view>
 9   <scroll-view class='right' scroll-y scroll-into-view="{{viewId}}">
10     <view class="jy-detail" wx:for="{{jydetail}}" wx:key="id" id= "D-{{detail.typeid}}-{{detail.id}}" wx:for-item="detail" bindtap='showDetail' data-id="{{detail.id}}">
11       <image src="{{detail.url}}"></image>
12       <label>{{detail.name}}</label>
13     </view>
14   </scroll-view>
15 </view>

JS代碼以下:學習

1   showItem: function(event) {
2     var that=this;
3     var viewId = "D-" + event.currentTarget.dataset.id + "-" + event.currentTarget.dataset.id+"00";
4     that.setData({
5       viewId: viewId
6     });
7     console.log(viewId);
8   },

WXSS佈局以下,此處主要用到了盒子佈局(display: flex;flex-direction: row;):flex

 1 .show-info {
 2   height: 100%;
 3   display: flex;
 4   flex-direction: row;
 5   align-items: flex-start;
 6   padding: 10rpx 0;
 7   box-sizing: border-box;
 8 }
 9 
10 .left {
11   width: 30%;
12   height: 100%;
13   display: flex;
14   flex-direction: column;
15   margin:2px;
16 }
17 
18 .jy-item-hover{
19   border: none;
20 }
21 
22 .right {
23   width: 70%;
24   height: 1200rpx;
25   display: flex;
26   flex-direction: column;
27   margin: 2px;
28 }

備註

學而時習之,不亦說乎。this

相關文章
相關標籤/搜索