记录,避免之后忘记......
一、目的:实现左右联动
- 右->左 滚动(上拉/下拉)右侧,左侧对应品类选中
- 左->右 点击左侧品类,右侧显示对应品类
data:image/s3,"s3://crabby-images/1e1e0/1e1e03c1c1ead9b999fa9b20438464c370e88e8f" alt=""
二、实现右->左 滚动(上拉/下拉)右侧,左侧对应品类选中
data:image/s3,"s3://crabby-images/72e96/72e9688405e0f8597f14a29bac655b201917a022" alt=""
1.在data()中初始化需要用到的数据
data:image/s3,"s3://crabby-images/810d1/810d11ae7516c4661100dafb116ee195c0ef55aa" alt=""
须知:左侧哪个品类选中是根据trigger==index比较得出的
data:image/s3,"s3://crabby-images/477fa/477fa0951d4966a43cd5cd7718aed17212348ad1" alt=""
2.在onLoad()中调用getheight()获取右侧各品类高度,给this.heightset数组赋值
javascript
// 回调函数,在数据发生改变时,在渲染dom之后,回制动执行回调函数
// 获取不同分类的高度
this.$nextTick(()=>{
this.getheight()
})
getheight()函数:
data:image/s3,"s3://crabby-images/90a56/90a562da9d0dcd436d5ae58af06795a981af41fe" alt=""
javascript
// 获取右侧各分类高度
getheight(){
const query=wx.createSelectorQuery()
query.selectAll('.rig-height').boundingClientRect()
query.exec(res=>{
let height=0
res[0].forEach(item=>{
height = height+item.height
this.heightset.push(height)
})
console.log(this.heightset);
})
}
打印结果:
data:image/s3,"s3://crabby-images/a57c4/a57c4cccee341e10c4903d822b2c551a2fcf7b3d" alt=""
3.给右侧<scroll-view>组件绑定滚动函数@scroll="scrollRight",根据实际滚动高度与当前品类高度比较结果改变trigger进而改变左侧选中品类。
data:image/s3,"s3://crabby-images/a6cd6/a6cd6301ba5161250d20e57a192347a0e8b7b047" alt=""
data:image/s3,"s3://crabby-images/b2f29/b2f29767d3cae1dab94774a75457775aab53d64f" alt=""
javascript
// 右侧滚动触发
scrollRight(e){
// console.log(e.detail.scrollTop)//获取当前滚动实际高度
if(e.detail.scrollTop>=this.heightset[this.trigger]){//上拉到下一个品类
this.trigger++
}else{
if(e.detail.scrollTop<this.heightset[this.trigger-1]){//下拉到上一个品类
this.trigger--
}
}
}
三、实现左->右 点击左侧品类,右侧显示对应品类
data:image/s3,"s3://crabby-images/c2771/c2771c0ff6ffcaf4e18a814b3da56ad9199eabd2" alt=""
1.使用scroll-view组件的scroll-into-view属性实现
data:image/s3,"s3://crabby-images/d7de7/d7de77f30faaf4f3b27f24f71f2f21b0b4f3f55a" alt=""
2.给左侧各品类绑定点击函数,改变this.trigger和this.scroll_into
data:image/s3,"s3://crabby-images/fe89e/fe89edb6de0e972f5361589423806571fb9705c8" alt=""
data:image/s3,"s3://crabby-images/39493/39493e2b4408230be21ebd7cf6f0e777d211ecbd" alt=""