本文以一個簡單的小例子,簡述在微信小程式開發中左右佈局功能的實現方式,主要涉及scroll-view ,列表數據綁定,及簡單樣式等內容,僅供學習分享使用。 ...
本文以一個簡單的小例子,簡述在微信小程式開發中左右佈局功能的實現方式,主要涉及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;):
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 }
備註
學而時習之,不亦說乎。