久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

vue實(shí)現(xiàn)錨點(diǎn)跳轉(zhuǎn)scrollIntoView()使用案例

瀏覽:8日期:2022-06-12 18:56:23
目錄vue實(shí)現(xiàn)錨點(diǎn)跳轉(zhuǎn):scrollIntoView()說(shuō)明:使用案例:vue錨點(diǎn)跳轉(zhuǎn)的三種方式(頁(yè)內(nèi)跳轉(zhuǎn),跨頁(yè)跳轉(zhuǎn),函數(shù)跳轉(zhuǎn))1.需求2.跳轉(zhuǎn)錨點(diǎn)的基本方式2.1 頁(yè)面內(nèi)通過(guò)點(diǎn)擊來(lái)跳轉(zhuǎn)2.2 從A頁(yè)面跳轉(zhuǎn)到B頁(yè)面的指定錨點(diǎn)(錨點(diǎn)就在頁(yè)面上,不在子組件中)2.3 直接使用代碼進(jìn)行錨點(diǎn)跳轉(zhuǎn)vue實(shí)現(xiàn)錨點(diǎn)跳轉(zhuǎn):scrollIntoView()說(shuō)明:

滾動(dòng)到某個(gè)特定元素 :scrollIntoView();例如form表單或者div滾動(dòng)到底部,

document.getElementsByClassName(‘’)或者document.getElementsById(‘’)

獲取到元素后即可實(shí)現(xiàn)回到可視化區(qū)域(也可理解為回到頂部)。

使用案例:<div> v-for='(value,index) in data' class='roll'>{{...}}</div>

js部分

methods:{ scrollToPosition(index){ document.getElementsByClassName('roll')[index].scrollIntoView()}

這樣就利用scrollIntoView()簡(jiǎn)單實(shí)現(xiàn)了一個(gè)錨點(diǎn)跳轉(zhuǎn),下邊講解scrollIntoView中的一些屬性:

scrollIntoView(true)相等于scrollIntoView();元素的頂端將和其所在滾動(dòng)區(qū)的可視區(qū)域的頂端對(duì)齊為true時(shí)相應(yīng)的 scrollIntoViewOptions: {block: “start”, inline:“nearest”}。這是這個(gè)參數(shù)的默認(rèn)值。

scrollIntoView(false)元素的底端將和其所在滾動(dòng)區(qū)的可視區(qū)域的底端對(duì)齊為false時(shí)相應(yīng)的scrollIntoViewOptions: {block: “end”, inline: “nearest”}。

同時(shí)他的參數(shù)也可以配置成一個(gè)object對(duì)象

scrollIntoView({ behavior:auto //定義動(dòng)畫過(guò)渡效果'auto'或 'smooth' 之一。默認(rèn)為 'auto'。 block:start//定義垂直方向的對(duì)齊, 'start', 'center', 'end', 或 'nearest'之一。默認(rèn)為 'start'。 inline:nearest//'start', 'center', 'end', 或 'nearest'之一。默認(rèn)為 'nearest'。 })

其中smooth是平滑滾動(dòng) start和end是目標(biāo)滾動(dòng)到的位置

注意:兼容性的問(wèn)題多數(shù)主流瀏覽器已經(jīng)支持其基本功能,也就是說(shuō),使用true,false兩個(gè)參數(shù),來(lái)實(shí)現(xiàn)木訥的定位(沒(méi)有滾動(dòng)動(dòng)畫)是沒(méi)有任何問(wèn)題的,但是傳入object參數(shù)時(shí),IE各種版本會(huì)直接忽略,全部看成true參數(shù)屬性,如果想看到滾動(dòng)動(dòng)畫,使用火狐和chrome。

vue錨點(diǎn)跳轉(zhuǎn)的三種方式(頁(yè)內(nèi)跳轉(zhuǎn),跨頁(yè)跳轉(zhuǎn),函數(shù)跳轉(zhuǎn))1.需求

最近遇到一個(gè)需求,需要從一個(gè)頁(yè)面跳到另一個(gè)頁(yè)面的指定錨點(diǎn),如果是頁(yè)面上的錨點(diǎn)還簡(jiǎn)單,但是那個(gè)錨點(diǎn)在頁(yè)面的組件里面。所以稍微研究了一下

2.跳轉(zhuǎn)錨點(diǎn)的基本方式2.1 頁(yè)面內(nèi)通過(guò)點(diǎn)擊來(lái)跳轉(zhuǎn)

即添加一個(gè)a標(biāo)簽,href以#開頭,然后在需要跳轉(zhuǎn)的地方添加一個(gè)element,id設(shè)置為a標(biāo)簽href屬性相同的值,只是不要#,就可以了,這是最簡(jiǎn)單的方式

<a >去找喵星人</a><h3 id='miao'>喵星人基地</h3>2.2 從A頁(yè)面跳轉(zhuǎn)到B頁(yè)面的指定錨點(diǎn)(錨點(diǎn)就在頁(yè)面上,不在子組件中)

我用的vue,所以在vue路由跳轉(zhuǎn)時(shí)只要在path后面加上#錨點(diǎn)就可以了,比如我要跳到B頁(yè)面id為miao的錨點(diǎn),那么path=xxxx?#miao,當(dāng)遇到query參數(shù)的情況,將#miao放到url的最后就行了,其他的也一樣,反正只要把錨點(diǎn)放在url最后就行了,然后進(jìn)行跳轉(zhuǎn)即可

?this.$router.push({? ? ? ? ? ? path: `/detail?#miao`,? ? ? ? ? ? query: {? ? ? ? ? ? ? comment: `${commentId}`? ? ? ? ? ? }? ? ? ? ? })

注意:因?yàn)槟J(rèn)的vue單頁(yè)使用的是hash模式,以#作為路由分割標(biāo)識(shí)符,就會(huì)導(dǎo)致有歧義而無(wú)法正常達(dá)到需求,如果你又不想使用history模式,那么就使用2.3的方式,使用代碼進(jìn)行錨點(diǎn)跳轉(zhuǎn)

2.3 直接使用代碼進(jìn)行錨點(diǎn)跳轉(zhuǎn)

有的情況,只能使用代碼進(jìn)行錨點(diǎn)跳轉(zhuǎn),比如從一個(gè)頁(yè)面跳到另一頁(yè)面子組件內(nèi)的指定錨點(diǎn),這與2.2還是有區(qū)別的,我已經(jīng)試過(guò),如果錨點(diǎn)在子組件內(nèi),不在當(dāng)前路由頁(yè)面中,那么2.2的方式并不會(huì)起作用。解決方法:將錨點(diǎn)作為query屬性,或者其他的方式,將錨點(diǎn)的值傳給B頁(yè)面,然后B頁(yè)面再通過(guò)props的方式傳給他的子組件,最后在子組件中使用代碼進(jìn)行錨點(diǎn)跳轉(zhuǎn)

// 這是傳到組件中的數(shù)據(jù)?props: {? ? ? commentId: String? }? mounted () {? // 判斷commentId 是否有值,如果沒(méi)有的話,就不進(jìn)行跳轉(zhuǎn),我這里就用'null'來(lái)判斷了,你們隨意? // document.querySelector用來(lái)獲取element,有個(gè)坑,id值不能全為數(shù)字,否則報(bào)錯(cuò),所以我在id值前面加了id,id格式大致是:id123456? // scrollIntoView就是用來(lái)跳轉(zhuǎn)到錨點(diǎn)的函數(shù)? ? ? ? if (this.commentId !== 'null') {? ? ? ? ? let inter = setInterval(() => {? ? ? ? ? ? let target = document.querySelector(`#id${this.commentId}`)? ? ? ? ? ? if (target) {? ? ? ? ? ? ? clearInterval(time)? ? ? ? ? ? ? target.scrollIntoView()? ? ? ? ? ? }? ? ? ? ? },100)? ? ? ? }? ? },

到此這篇關(guān)于vue實(shí)現(xiàn)錨點(diǎn)跳轉(zhuǎn) scrollIntoView()的文章就介紹到這了,更多相關(guān)vue錨點(diǎn)跳轉(zhuǎn) scrollIntoView()內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: JavaScript
主站蜘蛛池模板: 人一级毛片| 国产一区精品在线 | 网站一区二区三区 | 午夜精品久久久久 | 久久精品性 | 国产亚洲精品久 | 国产日韩欧美一区二区 | 黄色一级免费电影 | 国产玖玖 | 成年人精品视频在线观看 | 一区二区av | 一区二区毛片 | 免费国产一区二区 | 欧美精品在线一区二区 | 天天干天天干天天干天天射 | 国产a一三三四区电影 | 自拍偷拍欧美 | 日日操夜夜操免费视频 | 亚洲高清视频在线 | 成人在线视频播放 | 亚洲精品日韩激情在线电影 | 精久久| 欧美精品欧美极品欧美激情 | 日韩www| 国产精品久久精品 | 一区二区视频网 | 午夜一区二区三区 | 欧美激情欧美激情在线五月 | 男人天堂视频网 | 亚洲成人高清在线 | 中文字幕在线永久在线视频 | 日韩一二三 | 国产精品免费看 | 国产精品亚洲欧美日韩一区在线 | 999久久国产| 成人久久精品 | av大片在线观看 | 一本色道精品久久一区二区三区 | 国产乱xxxxx97国语对白 | 欧美日韩视频 | 一级做a爰片性色毛片2021 |