mpvue實(shí)現(xiàn)左側(cè)導(dǎo)航與右側(cè)內(nèi)容的聯(lián)動(dòng)
本文實(shí)例為大家分享了mpvue左側(cè)導(dǎo)航與右側(cè)內(nèi)容聯(lián)動(dòng)的具體代碼,供大家參考,具體內(nèi)容如下
效果圖如下:
(1)左側(cè)導(dǎo)航聯(lián)動(dòng)右側(cè)內(nèi)容
實(shí)現(xiàn):點(diǎn)擊左側(cè)導(dǎo)航,右側(cè)內(nèi)容滑到對(duì)應(yīng)的位置,并且導(dǎo)航上有current當(dāng)前樣式。
mpvue用的還是微信小程序提供的組件scroll-view,它里面有一個(gè)屬性scroll-into-view,值為某子元素的id,滾動(dòng)到該元素。
template:
<scroll-view class="menu-wrapper" scroll-y> <ul> <li class="menu-item" v-for="(item,index) in goods" :class="index===currentIndex ? 'current' : ''" :key="index" @tap="selectMenu(index)"> {{item.name}} </li> </ul> </scroll-view> <scroll-view scroll-y :scroll-into-view="contentId" scroll-with-animation="true" class="foods-wrapper"> <ul> <li v-for="(item,i) in goods" :id="'con_'+i" class="food-list food-list-hook" :key="i"> </li> </ul> <scroll-view>
js:
data() { return { goods: [], contentId: '', // 每個(gè)food-list的id,scroll-into-view滾動(dòng)到對(duì)應(yīng)的id currentIndex: 0 } }, methods: { selectMenu(index) { this.contentId = `con_${index}` this.currentIndex = index } }
(2)在左側(cè)導(dǎo)航聯(lián)動(dòng)右側(cè)內(nèi)容的基礎(chǔ)上增加右側(cè)內(nèi)容聯(lián)動(dòng)左側(cè)導(dǎo)航
實(shí)現(xiàn):滑動(dòng)右側(cè)內(nèi)容區(qū)域,給左側(cè)對(duì)應(yīng)導(dǎo)航增加current樣式,并且當(dāng)導(dǎo)航高度過長,會(huì)聯(lián)動(dòng)其滾動(dòng)
補(bǔ)充:contentHeight是右側(cè)內(nèi)容scroll-view的高度,同時(shí)也是左側(cè)導(dǎo)航scroll-view的高度,navItemHeight是導(dǎo)航ul下每一個(gè)item的高度,當(dāng)導(dǎo)航下ul的高度超過scroll-view的高度,并且this.currentIndex * this.navItemHeight > this.contentHeight,導(dǎo)航才向上滾動(dòng)。
tempate:
<scroll-view class="menu-wrapper" :scroll-into-view="navId" scroll-with-animation="true" scroll-y> <ul class="menu-ul"> <li class="menu-item" v-for="(item,index) in goods" :id="'nav_'+index" :class="index===currentIndex ? 'current' : ''" :key="index" @tap="selectMenu(index)"> {{item.name}} </li> </ul> </scroll-view> <scroll-view scroll-y @scroll="onScroll" :scroll-into-view="contentId" scroll-with-animation="true" class="foods-wrapper"> <ul> <li v-for="(item,i) in goods" :id="'con_'+i" class="food-list food-list-hook" :key="i"> </li> </ul> </scroll-view>
js:
export default{ data() { return { goods: [], contentId: '', // 每個(gè)food-list的id,scroll-into-view滾動(dòng)到對(duì)應(yīng)的id navId: '', // 導(dǎo)航模塊對(duì)應(yīng)的id,用來聯(lián)動(dòng)內(nèi)容區(qū)域 currentIndex: 0, navulHeight: 0, // 導(dǎo)航里ul高度 navItemHeight: 0, // 每個(gè)導(dǎo)航高度 listHeight: [], // foods內(nèi)部塊的高度 contentHeight: [], // 內(nèi)容區(qū)域scroll-view高度 } }, watch: { currentIndex() { console.log(this.currentIndex) if (this.contentHeight < this.navulHeight) { let h = this.currentIndex * this.navItemHeight if (h > this.contentHeight) { // 導(dǎo)航滑動(dòng) this.navId = `nav_${this.currentIndex}` } else { this.navId = 'nav_0' } } } }, methods: { selectMenu(index) { this.contentId = `con_${index}` this.navId = `nav_${index}` this.currentIndex = index }, onScroll(e) { this.contentId = '' let scrollTop = e.target.scrollTop // console.log(scrollTop) let length = this.listHeight.length if (scrollTop >= this.listHeight[length - 1] - this.contentHeight) { return } else if (scrollTop > 0 && scrollTop < this.listHeight[0]) { this.currentIndex = 0 } for (let i = 0; i < length; i++) { if (scrollTop >= this.listHeight[i - 1] && scrollTop < this.listHeight[i]) { this.currentIndex = i } } // console.log(this.currentIndex) }, getFoodHeight() { var query = wx.createSelectorQuery() let h = 0 query.selectAll('.food-list-hook').boundingClientRect((rects) => { // console.log(rects) rects.forEach((rect) => { h += rect.height this.listHeight.push(h) }) // console.log(this.listHeight) }) query.select('.foods-wrapper').boundingClientRect((rect) => { this.contentHeight = rect.height }) query.select('.menu-ul').boundingClientRect((rect) => { this.navulHeight = rect.height }) query.select('.menu-item').boundingClientRect((rect) => { this.navItemHeight = rect.height }).exec() } }, watch: { goods() { // 獲取模塊高度,即food-list setTimeout(() => { this.getFoodHeight() }, 60) } } }
更多教程點(diǎn)擊《Vue.js前端組件學(xué)習(xí)教程》,歡迎大家學(xué)習(xí)閱讀。
關(guān)于vue.js組件的教程,請(qǐng)大家點(diǎn)擊專題vue.js組件學(xué)習(xí)教程進(jìn)行學(xué)習(xí)。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue項(xiàng)目npm?run?build打包dist文件及打包后空白解決辦法
npm run build 這個(gè)命令會(huì)執(zhí)行Vue CLI中預(yù)定義的打包配置,并將打包后的文件存放在"dist"文件夾中,這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目npm?run?build打包dist文件及打包后空白的解決辦法,需要的朋友可以參考下2023-10-10使用Vue.js和MJML創(chuàng)建響應(yīng)式電子郵件
這篇文章主要介紹了使用Vue.js和MJML創(chuàng)建響應(yīng)式電子郵件,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03vue點(diǎn)擊按鈕實(shí)現(xiàn)讓頁面的某一個(gè)元素全屏展示
這篇文章主要介紹了vue點(diǎn)擊按鈕實(shí)現(xiàn)讓頁面的某一個(gè)元素全屏展示,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10使用antv替代Echarts實(shí)現(xiàn)數(shù)據(jù)可視化圖表詳解
這篇文章主要為大家介紹了使用antv替代Echarts實(shí)現(xiàn)數(shù)據(jù)可視化圖表詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08Element 的 el-table 表格實(shí)現(xiàn)單元格合并功能
這篇文章主要介紹了Element 的 el-table 表格實(shí)現(xiàn)單元格合并功能,本文通過示例代碼給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧2024-07-07一文詳解如何在vue中實(shí)現(xiàn)文件預(yù)覽功能
很多Vue項(xiàng)目中都需要PDF文件預(yù)覽功能,比如合同ERP,銷售CRM,內(nèi)部文檔CMS管理系統(tǒng),內(nèi)置PDF文件在線預(yù)覽功能,下面這篇文章主要給大家介紹了關(guān)于如何在vue中實(shí)現(xiàn)文件預(yù)覽功能的相關(guān)資料,需要的朋友可以參考下2022-10-10