vue跳轉(zhuǎn)時(shí)根據(jù)url錨點(diǎn)(#xxx)實(shí)現(xiàn)頁(yè)面內(nèi)容定位的方法
介紹
本前端仔在做頁(yè)面跳轉(zhuǎn)的時(shí)候,被要求跳轉(zhuǎn)到頁(yè)面時(shí)候,把對(duì)應(yīng)部分的內(nèi)容自動(dòng)滾動(dòng)到頂部~
我一開(kāi)始想到的就是根據(jù)錨點(diǎn)<a href="#xxid">
進(jìn)行處理,但是發(fā)現(xiàn)不太好實(shí)現(xiàn)~
于是便自己研究了一個(gè)比較取巧的方法
一、實(shí)現(xiàn)原理
為了能夠方便處理這個(gè)跳轉(zhuǎn)邏輯,我首先就想要把定位的錨點(diǎn)放到 url 上面,
事實(shí)上很多網(wǎng)站都是這樣做的,比如掘金就是這樣做的:
http://www.dbjr.com.cn/server/320459u0g.htm#heading-2
上面的鏈接中 # 后面拼接的就是定位的錨點(diǎn),這種就是給頁(yè)面對(duì)應(yīng)位置的標(biāo)簽添加 id 即可
但是我的項(xiàng)目要定位的地方在一個(gè)子組件的滾動(dòng)區(qū)域內(nèi),觸發(fā)不了這個(gè)自動(dòng)滾動(dòng)效果,不知道為啥~
于是我便使用 watch 進(jìn)行監(jiān)聽(tīng),如果發(fā)現(xiàn)url中存在錨點(diǎn),也就是#拼接的字符串,就根據(jù)這個(gè)字符串為id獲取對(duì)應(yīng)的元素,然后將其進(jìn)行滾動(dòng)~
二、代碼(vue3 setup)
1、首先在需要跳轉(zhuǎn)的頁(yè)面的父組件上進(jìn)行監(jiān)聽(tīng),最好是頁(yè)面框架組件,這樣這個(gè)監(jiān)聽(tīng)效果會(huì)一直存在:
import { watch, nextTick } from 'vue'; import { useRoute } from 'vue-router'; const route = useRoute(); // 監(jiān)聽(tīng)路由變化,滾動(dòng)到對(duì)應(yīng)位置 watch(() => route.hash, (newVal, oldVal) => { let hash = window.location.hash; // hash 刪除第一個(gè)字符(當(dāng)前項(xiàng)目是hsah模式) hash = hash.slice(1); if(hash.indexOf('#') != -1) { nextTick(() => { let id = hash.split('#')[1]; id = decodeURIComponent(id); let el = document.getElementById(id); console.log('滾動(dòng)到:', id, el) if(el) { // 平滑滾動(dòng) setTimeout(() => { el.scrollIntoView({behavior: 'smooth'}); }, 0); } }) } })
由于我的項(xiàng)目路由是哈希模式,于是便先清除一個(gè)#,接著便獲取到錨點(diǎn)id,然后獲取對(duì)應(yīng)的標(biāo)簽,最后進(jìn)行滾動(dòng) 為啥使用setTimeout呢?因?yàn)関ue的數(shù)據(jù)更新會(huì)有延遲的,代碼并不會(huì)立即執(zhí)行,因此使用定時(shí)器把這次滾動(dòng)推遲到下一個(gè)事件循環(huán),確保成功觸發(fā)~
2、在對(duì)應(yīng)的子組件中,也就是滾動(dòng)容器組件,只需要給對(duì)應(yīng)的位置的標(biāo)簽添加 id 即可
3、使用方法,router 跳轉(zhuǎn):
import { useRouter } from 'vue-router'; const router = useRouter() // 跳轉(zhuǎn) router.push({ path: '/xxx/xxxxx', hash: '#位置'})
三、演示:
四、結(jié)束
到此這篇關(guān)于vue跳轉(zhuǎn)時(shí)根據(jù)url錨點(diǎn)(#xxx)實(shí)現(xiàn)頁(yè)面內(nèi)容定位的方法的文章就介紹到這了,更多相關(guān)vue根據(jù)url錨點(diǎn)定位內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決echarts中橫坐標(biāo)值顯示不全(自動(dòng)隱藏)問(wèn)題
這篇文章主要介紹了解決echarts中橫坐標(biāo)值顯示不全(自動(dòng)隱藏)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07vue3實(shí)現(xiàn)動(dòng)態(tài)側(cè)邊菜單欄的幾種方式簡(jiǎn)單總結(jié)
在做開(kāi)發(fā)中都會(huì)遇到的需求,每個(gè)用戶的權(quán)限是不一樣的,那他可以訪問(wèn)的頁(yè)面(路由)可以操作的菜單選項(xiàng)是不一樣的,如果由后端控制,我們前端需要去實(shí)現(xiàn)動(dòng)態(tài)路由,動(dòng)態(tài)渲染側(cè)邊菜單欄,這篇文章主要給大家介紹了關(guān)于vue3實(shí)現(xiàn)動(dòng)態(tài)側(cè)邊菜單欄的幾種方式,需要的朋友可以參考下2024-02-02通過(guò)vue提供的keep-alive減少對(duì)服務(wù)器的請(qǐng)求次數(shù)
這篇文章主要介紹了通過(guò)vue提供的keep-alive減少對(duì)服務(wù)器的請(qǐng)求次數(shù),文中給大家補(bǔ)充介紹了vue路由開(kāi)啟keep-alive時(shí)的注意點(diǎn),需要的朋友可以參考下2018-04-04利用Vue3 (一)創(chuàng)建Vue CLI 項(xiàng)目
這篇文章主要介紹利用Vue3 創(chuàng)建Vue CLI 項(xiàng)目,下面文章內(nèi)容附有官方文檔鏈接,安裝過(guò)程,需要的可以參考一下2021-10-10el-select 點(diǎn)擊按鈕滾動(dòng)到選擇框頂部的實(shí)現(xiàn)代碼
本文通過(guò)實(shí)例代碼給大家分享el-select 點(diǎn)擊按鈕滾動(dòng)到選擇框頂部效果,主要代碼是在visibleChange在這個(gè)popper里面找到.el-select-dropdown__list,感興趣的朋友跟隨小編一起看看吧2024-05-05vue任意關(guān)系組件通信與跨組件監(jiān)聽(tīng)狀態(tài)vue-communication
這篇文章主要介紹了vue任意關(guān)系組件通信與跨組件監(jiān)聽(tīng)狀態(tài)vue-communication,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10