微信小程序?qū)崿F(xiàn)購物頁面左右聯(lián)動
更新時間:2019年02月15日 11:36:24 作者:qq_38674970
這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)購物頁面左右聯(lián)動,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了微信小程序?qū)崿F(xiàn)購物頁面左右聯(lián)動的具體代碼,供大家參考,具體內(nèi)容如下
效果圖:
wxml
<view class="pro-container"> <scroll-view class="left-menu" scroll-y scroll-with-animation="true" scroll-top="{{leftMenuTop}}"> <view class="menu-item {{index===currentActiveIndex?'menu-active':''}}" wx:for="{{item}}" wx:key="{{item.index}}" id="{{index}}" catchtap='changeMenu' >{{item.typename}}</view> </scroll-view> <scroll-view v-if="item!=''" class="right-pro" bindscroll = "scroll" scroll-y scroll-with-animation="true" scroll-top="{{rightProTop}}"> <view class="pro-item" wx:for="{{item}}"> <view class="item-header">{{item.typename}}</view> <view class="pro-item-container"> <view wx:for="{{item.shop_goods}}" wx:key="{{index}}" class="pro-item-item"> <image lazy-load="true" src="{{item}}"></image> <text>{{item.goodname}}</text> </view> </view> </view> </scroll-view> </view>
wxss
.left-menu{ position: absolute; top: 0; left: 0; bottom: 0; right: 0; width: 180rpx; background-color: #f8f8f8; font-size: 32rpx; } ::-webkit-scrollbar{ width: 0; height: 0; color: transparent; } .left-menu .menu-item{ width: calc(100% - 16rpx); height: 80rpx; padding:0 8rpx; line-height: 80rpx; text-align: center; } .left-menu .menu-item.menu-active{ border-left:8rpx solid red; padding-left: 0; background-color: #fff; } /* 右邊商品區(qū)域 */ .right-pro{ position: absolute; left: 180rpx; top:0; bottom: 0; width:calc(100% - 180rpx); background-color: #fff; display: flex; overflow: hidden; } .right-pro .pro-item{ padding:20rpx; } .right-pro .item-header{ display: inline-block; font-size: 30rpx; line-height: 40rpx; color: #fff; background-color: red; padding:0rpx 30rpx; margin: 10rpx auto; } .right-pro .pro-item-container{ font-size: 28rpx; } .pro-item-item{ width: calc((100% - 180rpx) / 2 ); display:inline-block; } .right-pro .pro-item-container image{ width: 100rpx; height: 100rpx; display: block; margin: 0 auto; } .right-pro .pro-item-container text{ display: block; text-align: center; }
wxjs
let proListToTop = [], menuToTop = [], MENU = 0, windowHeight,timeoutId; // MENU ==> 是否為點擊左側(cè)進行滾動的,如果是,則不需要再次設置左側(cè)的激活狀態(tài) Page({ data: { proList: [], item: [], item2:[ { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, { "typename": "服飾", }, ], currentActiveIndex: 0 }, onLoad: function (options) { // ---------------------------ajax---------------------- var utilMd5 = require('../../utils/md5.js'); var md5 = utilMd5.hexMD5; var timestamp = new Date().getTime(); var that = this; var jsonStr = JSON.stringify({ "shopid": "34" }); var token = md5(jsonStr + timestamp) + timestamp; wx.request({ url: "https://api.jvjiewang.com/Home/Shop/goods", data: { jsonStr: jsonStr, token: token }, method: 'POST', header: { "Content-Type": "application/x-www-form-urlencoded" }, success: function (res) { console.log(res.data.respond); var items = res.data.respond; that.setData({ item: items }) } }) //----------------------------ajax---------------------- // 確保頁面數(shù)據(jù)已經(jīng)刷新完畢~ setTimeout(() => { this.getAllRects() }, 200) }, changeMenu(e) { // 改變左側(cè)tab欄操作 if (Number(e.target.id) === this.data.currentActiveIndex) return MENU = 1 this.setData({ currentActiveIndex: Number(e.target.id), rightProTop: proListToTop[Number(e.target.id)] }) this.setMenuAnimation(Number(e.target.id)) }, scroll(e) { for (let i = 0; i < proListToTop.length; i++) { if (e.detail.scrollTop < proListToTop[i] && i !== 0 && e.detail.scrollTop > proListToTop[i - 1]) { return this.setDis(i) } } // 找不到匹配項,默認顯示第一個數(shù)據(jù) if (!MENU) { this.setData({ currentActiveIndex: 0 }) } MENU = 0 }, setDis(i) { // 設置左側(cè)menu欄的選中狀態(tài) if (i !== this.data.currentActiveIndex + 1 && !MENU) { this.setData({ currentActiveIndex: i - 1 }) } MENU = 0 this.setMenuAnimation(i) }, setMenuAnimation(i){ // 設置動畫,使menu滾動到指定位置。 let self = this if (menuToTop[i]) { console.log(11111) // 節(jié)流操作 if(timeoutId){ clearTimeout(timeoutId) } timeoutId = setTimeout(()=>{ console.log(12138) self.setData({ leftMenuTop: (menuToTop[i].top - windowHeight) }) },50) } else { if (this.data.leftMenuTop === 0) return this.setData({ leftMenuTop: 0 }) } }, getActiveReacts(){ wx.createSelectorQuery().selectAll('.menu-active').boundingClientRect(function (rects) { return rects[0].top }).exec() }, getAllRects() { // 獲取商品數(shù)組的位置信息 wx.createSelectorQuery().selectAll('.pro-item').boundingClientRect(function (rects) { rects.forEach(function (rect) { proListToTop.push(rect.top) }) }).exec() // 獲取menu數(shù)組的位置信息 wx.createSelectorQuery().selectAll('.menu-item').boundingClientRect(function (rects) { wx.getSystemInfo({ success: function (res) { windowHeight = res.windowHeight / 2 rects.forEach(function (rect) { menuToTop.push({ top: rect.top, // animate:rect.top > windowHeight }) }) } }) }).exec() }, // 獲取系統(tǒng)的高度信息 getSystemInfo() { let self = this wx.getSystemInfo({ success: function (res) { windowHeight = res.windowHeight / 2 } }) } })
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript創(chuàng)建閉包的兩種方式的優(yōu)劣與區(qū)別分析
這篇文章主要介紹了JavaScript創(chuàng)建閉包的兩種方式的優(yōu)劣與區(qū)別分析的相關(guān)資料,需要的朋友可以參考下2015-06-06javascript中mouseover、mouseout使用詳解
這篇文章主要介紹了javascript中mouseover、mouseout使用詳解的相關(guān)資料,需要的朋友可以參考下2015-07-07JavaScript實現(xiàn)導入和導出Excel的示例詳解
在現(xiàn)代的Web應用開發(fā)中,與Excel文件的導入和導出成為了一項常見而重要的任務,本文主要介紹了如何在熟悉的電子表格?UI?中輕松導入?Excel?文件,需要的可以參考下2024-03-03HTML+CSS+JavaScript實現(xiàn)可拖拽模態(tài)框
這篇文章主要為大家詳細介紹了HTML+CSS+JavaScript實現(xiàn)可拖拽模態(tài)框,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07json前后端數(shù)據(jù)交互相關(guān)代碼
本篇文章給大家分享了關(guān)于json前后端數(shù)據(jù)交互方法實現(xiàn)的相關(guān)知識點內(nèi)容,有興趣的讀者們可以參考學習下。2018-09-09