vue3錨點(diǎn)定位兩種實(shí)現(xiàn)方式示例
方法1: 利用ref實(shí)現(xiàn)錨點(diǎn)定位 前面的廢話文學(xué)
說(shuō)到錨點(diǎn)定位,很多人第一時(shí)間會(huì)想到 a標(biāo)簽。但是a標(biāo)簽實(shí)現(xiàn)的錨點(diǎn)定位并不是那么的完美,特別是在hash模式下。
對(duì)我而言,vue3的ref就實(shí)在是太完美了。
解決問(wèn)題的方法
很多情況下,我們會(huì)循環(huán)一定格式的數(shù)據(jù)對(duì)頁(yè)面進(jìn)行渲染,然后再有錨點(diǎn)定位的需求。那么我們?cè)撛趺慈プ瞿兀?/p>
1. setup函數(shù)內(nèi)定義變量
const eleRefs = ref([]); const setRef = (el) => { if (el) { eleRefs.value.push(el); } }; //獲取變量值 console.log(eleRefs.value[0])
2. 動(dòng)態(tài)獲取ref并存放到eleRefs數(shù)組當(dāng)中
<template v-for="(item, index) in data.catalogue"> <div class="part-cont" :id="'part' + item.id" :ref="setRef"> <div class="part-box"> <template v-for="(j, k) in item.picUrls" :key="k"> <img :src="j" alt=""> </template> </div> <template v-for="(i, ind) in item.children"> <div :id="'part' + i.id" :ref="setRef" class="part-box"> <template v-for="(j, k) in i.picUrls" :key="k"> <img :src="j" alt=""> </template> </div> </template> </div> </template>
3. 滾動(dòng)到特定的ref位置
eleRefs.value[0].scrollIntoView({ block: 'start', behavior: 'smooth' });
over
方法2: 利用a標(biāo)簽實(shí)現(xiàn)錨點(diǎn)定位(滾動(dòng)響應(yīng))
第二次的廢話文學(xué)
小編想了,還是想把a(bǔ)標(biāo)簽的錨點(diǎn)定位也記錄一下。
無(wú)論是PC端、移動(dòng)端,還是APP、小程序,只要涉及長(zhǎng)篇文章/畫(huà)冊(cè)、tab切換等的都可能會(huì)有錨點(diǎn)定位的需求。我們前端就需要做到點(diǎn)擊錨點(diǎn)能定位,滾動(dòng)頁(yè)面能響應(yīng)。
解決問(wèn)題的方法
1. a標(biāo)簽 定位到指定位置
// 錨記 <a href="#site" rel="external nofollow" >點(diǎn)擊此處到目標(biāo)位置</a> // 錨記位置 <div id="site"></div>
2.滾動(dòng)響應(yīng)
監(jiān)聽(tīng)滾動(dòng)事件
let currSite = document.documentElement.scrollTop || document.body.scrollTop // document.documentElement.scrollTop // 當(dāng)前滾動(dòng)位置 let windowHeight =window.innerHeight||document.documentElement.clientHeight || document.body.clientHeight // 視口高度 // 獲取元素信息 let ele = document.getElementById('site') let eleTop = ele.offsetTop // 元素距頁(yè)面頂部高度(頭部) let eleHeight = ele.clientHeight // 元素高度 let eleBot = eleHeight + eleTop // 元素底部距頁(yè)面頂部高度(尾部) /* 判斷元素是否在可視區(qū)域: 1.元素內(nèi)嵌可視區(qū)域(首尾均在可視區(qū)域內(nèi)) 2.元素外嵌可視區(qū)域(首位均在可視區(qū)域外) 3.元素頭部在可視區(qū)域內(nèi),尾部在可視區(qū)域外 */ if(eleTop >= currSite &&eleTop < currSite + windowHeight || (eleBot > currSite &&eleBot < currSite + windowHeight) || (eleTop e < currSite && eleBot > currSite + windowHeight)){ // 元素在可視區(qū)域 }else{ // 元素不在可視區(qū)域 }
over
總結(jié)
到此這篇關(guān)于vue3錨點(diǎn)定位兩種實(shí)現(xiàn)方式的文章就介紹到這了,更多相關(guān)vue3錨點(diǎn)定位內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
VUE使用DXFParser組件解析dxf文件生成圖片的操作代碼
這篇文章主要介紹了VUE使用DXFParser組件解析dxf文件生成圖片的操作代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09Vue過(guò)濾器(filter)實(shí)現(xiàn)及應(yīng)用場(chǎng)景詳解
在Vue中使用過(guò)濾器(Filters)來(lái)渲染數(shù)據(jù)是一種很有趣的方式,下面這篇文章主要給大家介紹了關(guān)于Vue過(guò)濾器(filter)實(shí)現(xiàn)及應(yīng)用場(chǎng)景的相關(guān)資料,需要的朋友可以參考下2021-06-06解決antd datepicker 獲取時(shí)間默認(rèn)少8個(gè)小時(shí)的問(wèn)題
這篇文章主要介紹了解決antd datepicker 獲取時(shí)間默認(rèn)少8個(gè)小時(shí)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10如何解決vue-json-editor無(wú)法輸入中文、重影問(wèn)題
文章介紹了如何解決vue-json-editor組件無(wú)法輸入中文和重影的問(wèn)題,通過(guò)修改源碼并使用vue-json-edit-fix-cn組件來(lái) fix 這兩個(gè)問(wèn)題,同時(shí),文章還提供了如何移除舊的依賴包并安裝新的依賴包的步驟2025-01-01vue增加強(qiáng)緩存和版本號(hào)的實(shí)現(xiàn)方法
這篇文章主要介紹了vue增加強(qiáng)緩存和版本號(hào)的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05vue中ref引用操作DOM元素的實(shí)現(xiàn)
本文主要介紹了vue中ref引用操作DOM元素的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01Vue使用el-input自動(dòng)獲取焦點(diǎn)和二次獲取焦點(diǎn)問(wèn)題及解決
這篇文章主要介紹了Vue使用el-input自動(dòng)獲取焦點(diǎn)和二次獲取焦點(diǎn)問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12Vue中保存數(shù)據(jù)到磁盤(pán)文件的方法
今天小編就為大家分享一篇Vue中保存數(shù)據(jù)到磁盤(pán)文件的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09