知識(shí)
不管是網(wǎng)站,軟件還是小程序,都要直接或間接能為您產(chǎn)生價(jià)值,我們?cè)谧非笃湟曈X表現(xiàn)的同時(shí),更側(cè)重于功能的便捷,營(yíng)銷的便利,運(yùn)營(yíng)的高效,讓網(wǎng)站成為營(yíng)銷工具,讓軟件能切實(shí)提升企業(yè)內(nèi)部管理水平和效率。優(yōu)秀的程序?yàn)楹笃谏?jí)提供便捷的支持!
您當(dāng)前位置>首頁 » 新聞資訊 » 小程序相關(guān) >
微信小程序?qū)崿F(xiàn)頂部、底部滑動(dòng)聯(lián)動(dòng)
發(fā)表時(shí)間:2021-3-31
發(fā)布人:葵宇科技
瀏覽次數(shù):87
這個(gè)場(chǎng)景一般用于展示數(shù)據(jù)時(shí),數(shù)據(jù)過多,每條一行顯示不下,表頭可以橫向滑動(dòng),下面要顯示的數(shù)據(jù)部分橫向縱向都可以滑動(dòng)。表頭或下面數(shù)據(jù)部分橫向滑動(dòng)的時(shí)候,兩部分可以進(jìn)行聯(lián)動(dòng)
具體效果像這樣(隨便寫的丑樣式布局)
說說原理,主要是使用兩個(gè)scroll-view組件,然后監(jiān)聽兩個(gè)scroll-view的滑動(dòng)事件,然后根據(jù)滑動(dòng)的scroll-view橫向滑動(dòng)的距離,通過scroll-left來設(shè)置另一個(gè)scroll-view滑動(dòng)的距離
首先WXML代碼:
<scroll-view style='width:100%;height:100rpx;border:1px solid #f00;' scroll-x scroll-left='{{title_x}}' bindscroll='titlebindscroll' bindtouchstart='bindtouchstart' data-types='title'>
<view style='height:300rpx;background:#00f;width:1000rpx;margin-bottom:10rpx;float:left;color:#fff;'>12122665566546546546512346846546465465466666666666666666666666644444444444488888888888888888888999999999999999995555555555555553333333333333333222222222222222777777777776666666666666666666666555555555555533333333332222222</view>
</scroll-view>
<scroll-view style='width:100%;height:1000rpx;border:1px solid #f00;' scroll-x scroll-yscroll-left='{{title_x}}' bindscroll='bindscroll' bindtouchstart='bindtouchstart' data-types='data'>
<view style='height:300rpx;background:#f00;width:1000rpx;margin-bottom:10rpx;float:left;' wx:for='{{[1,1,1,11,1,1,1,1,1,11,1,1,1]}}'>12122665566546546546512346846546465465466666666666666666666666644444444444488888888888888888888999999999999999995555555555555553333333333333333222222222222222777777777776666666666666666666666555555555555533333333332222222</view>
</scroll-view>
然后JS代碼:
let ifs=true;//這里添加一個(gè)開關(guān),因?yàn)樵谠O(shè)置一個(gè)scroll的滑動(dòng)距離的時(shí)候會(huì)觸發(fā)這個(gè)scroll的滑動(dòng)事件,從而執(zhí)行里面的事件,這樣會(huì)做很多多余的操作,影響性能
Page({
data: {
title_x:0
},
//在開發(fā)者工具上前幾次滑動(dòng)會(huì)很慢,估計(jì)幾秒后另一個(gè)才會(huì)滑動(dòng),手機(jī)上不會(huì),在手機(jī)和開發(fā)者工具上滑動(dòng)的時(shí)候有大概幾百毫秒延遲,可以忽略不計(jì),我覺得是因?yàn)閮蓚€(gè)地方的滑動(dòng)都要頻繁的使用setData操作,所以會(huì)出現(xiàn)這些情況,如果大家發(fā)現(xiàn)是其他原因引起的、有錯(cuò)誤或有其他好的方法,請(qǐng)留言,謝謝
//判斷是那個(gè)部分在滑動(dòng)
bindtouchstart(e){
const types=e.currentTarget.dataset.types;
ifs=(types=='title');//
console.log(ifs);
},
//下面紅色部分滑動(dòng)
bindscroll(e){
let move = e.detail.scrollLeft,//獲取下面紅色部分的橫向滑動(dòng)距離
title_x=this.data.title_x;
if (title_x!=move&&!ifs){//監(jiān)聽srcoll滑動(dòng)事件,判斷下面紅色部分與左邊的距離和藍(lán)色部分與左邊的距離是否相等,相等的話就是縱向滑動(dòng),否則就是橫向滑動(dòng),只有橫向滑動(dòng)的時(shí)候才改變藍(lán)色部分滑動(dòng)的距離
this.setData({//這里需要實(shí)時(shí)渲染
title_x: move
});
}
},
//藍(lán)色部分滑動(dòng)
titlebindscroll(e){
const move = e.detail.scrollLeft;//獲取藍(lán)色部分滑動(dòng)的距離
if(ifs){
this.setData({//更新下面紅色距離左邊的距離,這里是滑動(dòng)藍(lán)色部分然后設(shè)置下面滑動(dòng)的距離,所以要用setData進(jìn)行渲染
title_x:move
});
}
},
onLoad: function (options) {
}
})
在開發(fā)者工具上前幾次滑動(dòng)會(huì)很慢,估計(jì)幾秒后另一個(gè)才會(huì)滑動(dòng),手機(jī)上不會(huì)。
在手機(jī)和開發(fā)者工具上滑動(dòng)的時(shí)候有大概幾百毫秒延遲,可以忽略不計(jì),
我覺得是因?yàn)閮蓚€(gè)地方的滑動(dòng)都要頻繁的使用setData操作,所以會(huì)出現(xiàn)這些情況。
如果大家發(fā)現(xiàn)是其他原因引起的、有錯(cuò)誤或有其他好的方法,請(qǐng)留言,謝謝
相關(guān)案例查看更多
相關(guān)閱讀
- 云南網(wǎng)站建設(shè)專家
- 云南網(wǎng)站建設(shè)哪家強(qiáng)
- 汽車回收系統(tǒng)
- 網(wǎng)站建設(shè)專業(yè)品牌
- 云南電商網(wǎng)站建設(shè)
- 云南建設(shè)廳網(wǎng)站
- 云南小程序設(shè)計(jì)
- 網(wǎng)站建設(shè)百度官方
- 云南小程序被騙
- 云南網(wǎng)站建設(shè)一條龍
- 網(wǎng)絡(luò)營(yíng)銷
- 怎么做網(wǎng)站
- 小程序開發(fā)平臺(tái)前十名
- 百度自然排名
- flex
- 云南網(wǎng)站建設(shè)公司
- 開發(fā)微信小程序
- 云南小程序開發(fā)首選品牌
- 云南網(wǎng)絡(luò)公司
- 汽車回收管理系統(tǒng)
- 云南網(wǎng)站建設(shè)百度官方
- 網(wǎng)站建設(shè)公司哪家好
- 云南小程序開發(fā)課程
- 用戶登錄
- 北京小程序制作
- 跳轉(zhuǎn)小程序
- 昆明軟件公司
- 云南網(wǎng)絡(luò)推廣
- 云南省建設(shè)廳網(wǎng)站
- 云南企業(yè)網(wǎng)站