Vue滾動到指定位置的多種方式示例詳解
腳本之家推薦閱讀:
vue如何移動到指定位置(scrollIntoView)親測避坑
需求:
當(dāng)容器有滾動條時,有時需要將指定的內(nèi)容自動滾動到可視區(qū)域。
方法一:錨點
錨點通過在元素上設(shè)置id,然后用a標(biāo)簽的href="#id"屬性跳轉(zhuǎn)到指定位置。也可以通過js中 window.location.hash= ‘#id’ 或 window.location.href = ‘#id’ 來跳轉(zhuǎn)。
//dom <a href="#li50" rel="external nofollow" >跳到50</a> <ul class="ul" id="ul"> <li v-for="(item, index) in new Array(100)" :key="index" :id="'li' + (index + 1)"> {{ index + 1 }} 只羊 </li> </ul> //或者js window.location.hash= '#li50';
hash和href的區(qū)別:
- hash為錨鏈接,并不會跳轉(zhuǎn)到新的鏈接,只會在當(dāng)前鏈接里面改變錨鏈。
- href表示重定向,得到完整的url,頁面跳轉(zhuǎn)到新的頁面。
方法二:scrollTop
先計算指定dom距離頂部的高度offsetTop,再設(shè)置父元素的滾動距離scrollTop即可。
//dom <el-button type="primary" @click="link">跳到30</el-button> //js link() { let target = document.getElementById('li30'); let parent = document.getElementById('ul'); parent.scrollTop = target.offsetTop - parent.offsetTop; },
由于此處父元素距離頂部也有一定的高度,所以滾動距離需要先減去父元素的offsetTop,才是正確的滾動高度。
方法三:scrollTo
同scrollTop,只是換了種寫法
link() { let target = document.getElementById('li30'); let parent = document.getElementById('ul'); // parent.scrollTop = target.offsetTop - parent.offsetTop; parent.scrollTo(0, target.offsetTop - parent.offsetTop); },
也可以通過ref來指定dom
this.$refs.ul.scrollTo(0, 300);
方法四:scrollIntoView
簡單粗暴,將指定元素滾動到可視區(qū)域頂部、底部或中間:
behavior
定義動畫過渡效果:“auto”、 “smooth”
//頂部 document.getElementById('li60').scrollIntoView(); //底部 document.getElementById('li60').scrollIntoView(false); //中間 document.getElementById('li60').scrollIntoView({ behavior: "smooth", block: 'center' });
Element.scrollIntoView():https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollIntoView
到此這篇關(guān)于Vue滾動到指定位置的多種方式的文章就介紹到這了,更多相關(guān)Vue滾動到指定位置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue + elementUI實現(xiàn)省市縣三級聯(lián)動的方法示例
這篇文章主要介紹了vue + elementUI實現(xiàn)省市縣三級聯(lián)動的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10vue實現(xiàn)element表格里表頭信息提示功能(推薦)
小編最近接了這樣一個需求,需要在element表格操作一欄添加提示功能,下面小編給大家?guī)砹嘶趘ue實現(xiàn)element表格里表頭信息提示功能,需要的朋友參考下吧2019-11-11Vue利用自定義指令實現(xiàn)按鈕權(quán)限控制
這篇文章主要為大家詳細(xì)介紹了Vue如何利用自定義指令實現(xiàn)按鈕權(quán)限控制效果,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,需要的可以參考下2023-05-05Vue應(yīng)用qs插件實現(xiàn)參數(shù)格式化示例詳解
這篇文章主要為大家介紹了Vue應(yīng)用qs插件實現(xiàn)參數(shù)格式化示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09vue?props使用typescript自定義類型的方法實例
這篇文章主要給大家介紹了關(guān)于vue?props使用typescript自定義類型的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2023-01-01