溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信小程序之左右布局的實現(xiàn)代碼

發(fā)布時間:2020-10-04 17:52:05 來源:腳本之家 閱讀:315 作者:Alan.hsiang 欄目:web開發(fā)

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

概述

在微信小程序開發(fā)中,左右分欄(左邊顯示分類,右邊顯示明細,然后進行聯(lián)動)是一種常見的布局方式,多應用于點餐,冷飲店,外賣,以及其他類似的商城。

布局分析

布局分析圖示如下:

微信小程序之左右布局的實現(xiàn)代碼

涉及知識點

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

示例效果圖

示例效果圖如下所示:

微信小程序之左右布局的實現(xiàn)代碼

核心代碼

WXML代碼如下:

<!--pages/show/show.wxml-->
<view class="show-info">
 <scroll-view class='left' scroll-y>
  <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}}">
   <image src="{{item.url}}"></image>
   <label>{{item.name}}</label>
  </view>
 </scroll-view>
 <scroll-view class='right' scroll-y scroll-into-view="{{viewId}}">
  <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}}">
   <image src="{{detail.url}}"></image>
   <label>{{detail.name}}</label>
  </view>
 </scroll-view>
</view>

JS代碼如下:

showItem: function(event) {
  var that=this;
  var viewId = "D-" + event.currentTarget.dataset.id + "-" + event.currentTarget.dataset.id+"00";
  that.setData({
   viewId: viewId
  });
  console.log(viewId);
 },

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

.show-info {
 height: 100%;
 display: flex;
 flex-direction: row;
 align-items: flex-start;
 padding: 10rpx 0;
 box-sizing: border-box;
}

.left {
 width: 30%;
 height: 100%;
 display: flex;
 flex-direction: column;
 margin:2px;
}

.jy-item-hover{
 border: none;
}

.right {
 width: 70%;
 height: 1200rpx;
 display: flex;
 flex-direction: column;
 margin: 2px;
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI