vue中實(shí)現(xiàn)左右聯(lián)動(dòng)的效果
這里的坑還是蠻多的,花了一個(gè)多小時(shí),才理清楚。
做一下筆記,以便于復(fù)習(xí)。

首先呢,需要讓左右的布局都可以滾動(dòng),這里使用了betterScroll
npm i better-scroll
import BScroll from 'better-scroll'
methods: {
_initScroll () {
this.menuScroll = new BScroll((this.$refs.menu), {
click: true
因?yàn)閎etterscroll默認(rèn)會(huì)阻止點(diǎn)擊事件。這里要設(shè)置一下
})
this.foodScroll = new BScroll((this.$refs.good), {
probeType: 3
用來(lái)獲取滾動(dòng)的距離
})
this.foodScroll.on('scroll', (pos) => {
this.scrollY = Math.abs(Math.round(pos.y))
})
},
重點(diǎn):
created () {
this.$ajax.get('/api/data.json').then((res) => {
this.goods = res.data.goods
this.$nextTick(() => {
this._initScroll()
this.getGoodsHeight()
})
})
},
這里的代碼一定要在獲取數(shù)據(jù)里面寫nextTick()回調(diào)里面寫代碼,因?yàn)樾枰却龜?shù)據(jù)萬(wàn)泉加載再去初始化scroll和獲取右邊每一個(gè)盒子的高度。
說(shuō)道高度,高度如何獲取呢?
getGoodsHeight () {
let goodEle = this.$refs.good
let height = 0
this.listHeight.push(height)
let foodList = goodEle.getElementsByClassName('goodsItemHook')
for (let i = 0; i < foodList.length; i++) {
let item = foodList[i]
height += item.clientHeight
this.listHeight.push(height)
}
},
這里是獲取到每一個(gè)盒子的clientHeight的高度進(jìn)行疊加,在push到一個(gè)數(shù)組里面。
this.foodScroll.on('scroll', (pos) => {
this.scrollY = Math.abs(Math.round(pos.y))
})
獲取滾動(dòng)的值,賦值給scrollY。
然后根據(jù)scrollY 和listHeight的高度區(qū)間做對(duì)比,拿到index:
currentIndex () {
for (let i = 0; i < this.listHeight.length; i++) {
let height1 = this.listHeight[i]
let height2 = this.listHeight[i + 1]
if (!height2 || (this.scrollY < height2 && this.scrollY >= height1)) {
return i
}
}
}
這時(shí)候滾動(dòng)就能獲取index的值了,然后給左邊的元素去添加active的樣式就方便了。
:class="{'active': currentIndex == index}"
最后一步是如何實(shí)現(xiàn)點(diǎn)擊的時(shí)候去讓右邊的滾動(dòng)到指定的位置。
handleGoodsItem (index) {
let goodEle = this.$refs.good
let foodList = goodEle.getElementsByClassName('goodsItemHook')
let el = foodList[index]
this.foodScroll.scrollToElement(el, 300)
}
這里調(diào)用了scroll的方法:scrollToElement。
總結(jié)
以上所述是小編給大家介紹的vue中實(shí)現(xiàn)左右聯(lián)動(dòng)的效果,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- vue左右側(cè)聯(lián)動(dòng)滾動(dòng)的實(shí)現(xiàn)代碼
- Vue2仿淘寶實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)
- vue.js模仿京東省市區(qū)三級(jí)聯(lián)動(dòng)的選擇組件實(shí)例代碼
- vue基于mint-ui的城市選擇3級(jí)聯(lián)動(dòng)的示例
- vue mint-ui 實(shí)現(xiàn)省市區(qū)街道4級(jí)聯(lián)動(dòng)示例(仿淘寶京東收貨地址4級(jí)聯(lián)動(dòng))
- Vue中的ref作用詳解(實(shí)現(xiàn)DOM的聯(lián)動(dòng)操作)
- vue省市區(qū)三聯(lián)動(dòng)下拉選擇組件的實(shí)現(xiàn)
- 使用vue.js實(shí)現(xiàn)聯(lián)動(dòng)效果的示例代碼
相關(guān)文章
vue3.0 子組件如何修改父組件傳遞過(guò)來(lái)的值
這篇文章主要介紹了vue3.0 子組件如何修改父組件傳遞過(guò)來(lái)的值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
vue如何實(shí)現(xiàn)對(duì)請(qǐng)求參數(shù)進(jìn)行簽名
這篇文章主要介紹了vue如何實(shí)現(xiàn)對(duì)請(qǐng)求參數(shù)進(jìn)行簽名問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01
Vue v2.5 調(diào)整和更新不完全問(wèn)題
這篇文章主要介紹了Vue v2.5 調(diào)整和更新不完全問(wèn)題的相關(guān)資料,需要的朋友可以參考下2017-10-10
Vue.js實(shí)現(xiàn)按鈕的動(dòng)態(tài)綁定效果及實(shí)現(xiàn)代碼
本文通過(guò)實(shí)例代碼給大家介紹了Vue.js實(shí)現(xiàn)按鈕的動(dòng)態(tài)綁定效果,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧2017-08-08
基于vue.js仿淘寶收貨地址并設(shè)置默認(rèn)地址的案例分析
這篇文章主要介紹了基于vue.js仿淘寶收貨地址并設(shè)置默認(rèn)地址的案例分析,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
vue如何使用js對(duì)圖片進(jìn)行點(diǎn)擊標(biāo)注圓點(diǎn)并記錄它的坐標(biāo)
這篇文章主要介紹了vue如何使用js對(duì)圖片進(jìn)行點(diǎn)擊標(biāo)注圓點(diǎn)并記錄它的坐標(biāo),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
vue 監(jiān)聽(tīng)鍵盤回車事件詳解 @keyup.enter || @keyup.enter.native
今天小編就為大家分享一篇vue 監(jiān)聽(tīng)鍵盤回車事件詳解 @keyup.enter || @keyup.enter.native,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
Vue3+Vite+TS使用elementPlus時(shí)踩的坑及解決
這篇文章主要介紹了Vue3+Vite+TS使用elementPlus時(shí)踩的坑及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10

