Vue中的element tabs點(diǎn)擊錨點(diǎn)定位,鼠標(biāo)滾動定位
一、效果圖

二、代碼
- html
<el-tabs
class="customer-tab"
type="card"
@tab-click="jump"
v-model="tabName"
>
<el-tab-pane
v-for="(tab, index) in tabs"
:name="tab.refName"
:key="index"
:label="tab.name"
></el-tab-pane>
</el-tabs>
<div
class="scroll-content"
@scroll="onScroll"
:style="
'overflow-x: hidden; overflow-y: auto;height:' + contentStyleObj.height
"
>
<!-- 用戶管理 -->
<div :ref="tabs[0].refName" class="scroll-item">
<div class="line-name">
<h2>{{ tabs[0].name }}</h2>
</div>
<div>
<p
style="height: 40px"
v-for="item in [
0, 1, 2, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
]"
:key="item"
>
待發(fā)貨符合規(guī)范化如故
</p>
</div>
</div>
<!-- 配置管理 -->
<div :ref="tabs[1].refName" class="scroll-item">
<div class="line-name">
<h2>{{ tabs[1].name }}</h2>
</div>
<div>
<p
style="height: 40px"
v-for="item in [
0, 1, 2, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
]"
:key="item"
>
新能說出的基本功發(fā)到你DNF不得發(fā)布
</p>
</div>
</div>
<!-- 角色管理 -->
<div
:ref="tabs[2].refName"
class="scroll-item"
style="padding-top: 1rem; top: 5px"
>
<div class="line-name">
<h2>{{ tabs[2].name }}</h2>
</div>
<div>
<p
v-for="item in [
0, 1, 2, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
]"
:key="item"
>
新水泥廠劇場版
</p>
</div>
</div>
<!-- 角色管理2 -->
<div
:ref="tabs[3].refName"
class="scroll-item"
style="padding-top: 1rem; top: 5px"
>
<div class="line-name">
<h2>{{ tabs[3].name }}</h2>
</div>
<div>
<p
v-for="item in [
0, 1, 2, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
]"
:key="item"
>
新水泥廠劇場版
</p>
</div>
</div>
</div>- js
<script>
export default {
name: 'index',
props: {},
components: {},
data() {
return {
tabIndex: '0',
contentStyleObj: {
height: '100px',
},
tabName: 'setOneRef',
tabs: [
{
name: '用戶管理',
refName: 'setOneRef',
},
{
name: '配置管理',
refName: 'setTwoRef',
},
{
name: '角色管理',
refName: 'setThreeRef',
},
{
name: '角色管理2',
refName: 'setFourRef',
},
],
}
},
computed: {},
watch: {},
created() {
this.getHight()
window.addEventListener('resize', this.getHight)
},
destroyed() {
window.removeEventListener('resize', this.getHight)
},
methods: {
// tab click
jump(tab, event) {
let target = document.querySelector('.scroll-content')
let scrollItems = document.querySelectorAll('.scroll-item')
// 判斷滾動條是否滾動到底部
if (target.scrollHeight <= target.scrollTop + target.clientHeight) {
this.tabIndex = tab.index.toString()
}
let totalY = scrollItems[tab.index].offsetTop - scrollItems[0].offsetTop // 錨點(diǎn)元素距離其offsetParent(這里是body)頂部的距離(待滾動的距離)
let distance = document.querySelector('.scroll-content').scrollTop // 滾動條距離滾動區(qū)域頂部的距離
// let distance = document.body.scrollTop || document.documentElement.scrollTop || window.pageYOffset // 滾動條距離滾動區(qū)域頂部的距離(滾動區(qū)域?yàn)榇翱?
// 滾動動畫實(shí)現(xiàn), 使用setTimeout的遞歸實(shí)現(xiàn)平滑滾動,將距離細(xì)分為50小段,10ms滾動一次
// 計(jì)算每一小段的距離
let step = totalY / 50
if (totalY > distance) {
smoothDown(document.querySelector('.scroll-content'))
} else {
let newTotal = distance - totalY
step = newTotal / 50
smoothUp(document.querySelector('.scroll-content'))
}
// 參數(shù)element為滾動區(qū)域
function smoothDown(element) {
if (distance < totalY) {
distance += step
element.scrollTop = distance
setTimeout(smoothDown.bind(this, element), 10)
} else {
element.scrollTop = totalY
}
}
// 參數(shù)element為滾動區(qū)域
function smoothUp(element) {
if (distance > totalY) {
distance -= step
element.scrollTop = distance
setTimeout(smoothUp.bind(this, element), 10)
} else {
element.scrollTop = totalY
}
}
},
// 滾動條滾動
onScroll(e) {
let scrollItems = document.querySelectorAll('.scroll-item')
for (let i = scrollItems.length - 1; i >= 0; i--) {
// 判斷滾動條滾動距離是否大于當(dāng)前滾動項(xiàng)可滾動距離
let judge =
e.target.scrollTop >=
scrollItems[i].offsetTop - scrollItems[0].offsetTop - 400
if (judge) {
this.tabIndex = i.toString()
// 找對應(yīng)的tab-name值
this.tabName = this.tabs[this.tabIndex].refName
break
}
}
},
getHight() {
this.contentStyleObj.height = window.innerHeight - 190 + 'px'
},
},
}
</script>
- css
<style lang="scss" scoped>
::v-deep.customer-tab {
width: 100%;
height: 50px;
background-color:#f5f7fa;
padding: 4px;
}
::v-deep.el-tabs--card > .el-tabs__header {
border-bottom: none;
margin: 0;
.el-tabs__nav {
width: 100%;
display: flex;
justify-content: space-around;
border: none;
.el-tabs__item {
width: 25%;
text-align: center;
border: none;
}
.is-active {
border-radius: 4px;
background-color: #005BD9;
color: #fff;
}
}
}
</style>
總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue+elementui 對話框取消 表單驗(yàn)證重置示例
今天小編就為大家分享一篇vue+elementui 對話框取消 表單驗(yàn)證重置示例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10
在vue中封裝的彈窗組件使用隊(duì)列模式實(shí)現(xiàn)方法
這篇文章主要介紹了在vue中封裝的彈窗組件使用隊(duì)列模式實(shí)現(xiàn)方法,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07
vue用vis插件如何實(shí)現(xiàn)網(wǎng)絡(luò)拓?fù)鋱D
這篇文章主要介紹了vue用vis插件如何實(shí)現(xiàn)網(wǎng)絡(luò)拓?fù)鋱D,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
Vue3+Vite使用雙token實(shí)現(xiàn)無感刷新
本文主要介紹了Vue3+Vite使用雙token實(shí)現(xiàn)無感刷新,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
Vue實(shí)現(xiàn)首頁banner自動輪播效果
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)首頁banner自動輪播效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
解決vue中axios設(shè)置超時(超過5分鐘)沒反應(yīng)的問題
這篇文章主要介紹了解決vue中axios設(shè)置超時(超過5分鐘)沒反應(yīng)的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
淺談Vue.js 關(guān)于頁面加載完成后執(zhí)行一個方法的問題
這篇文章主要介紹了Vue.js 關(guān)于頁面加載完成后執(zhí)行一個方法的問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
vue?router進(jìn)行路由跳轉(zhuǎn)并攜帶參數(shù)的實(shí)例詳解(params/query)
在使用`router.push`進(jìn)行路由跳轉(zhuǎn)到另一個組件時,可以通過`params`或`query`來傳遞參數(shù),這篇文章主要介紹了vue?router進(jìn)行路由跳轉(zhuǎn)并攜帶參數(shù)(params/query),需要的朋友可以參考下2023-09-09

