本文小编为大家详细介绍“vue怎么实现顶部左右滑动导航”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue怎么实现顶部左右滑动导航”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
思路:判断当前点击项,相对与屏幕的位置,若点击的位置,满足可移动的限制,进行自动滑动处理。
实现如下:
vue
<template>
<div class="debug-index-page">
<div class="tab-layout" id="scroller">
<ul v-for="(tab, idx) in tabList" :key="idx">
<li
:id="`tab-${tab.id}`"
class="tab-item"
@click="onClickTab(tab)"
:
>
{{ tab.text }}
</li>
</ul>
</div>
</div>
</template>
JS
export default {
data() {
return {
tabList: [],
}
},
created() {
let list = [
"我的贵族",
"贵族1",
"我的贵族2",
"贵族3",
"贵族4",
"贵族5",
"我的贵族6",
"我的贵族7",
];
list.forEach((text, idx) => {
this.tabList.push({
text,
id: idx, // tab标识
select: idx == 0, // 是否被选择
index: idx // 处于显示的位置
});
});
},
computed: {
curTab() {
return this.tabList.find(v => v.select);
}
},
methods: {
onClickTab(tabInfo) {
let curTab = this.curTab;
if (curTab.id == tabInfo.id) return;
let { index, id } = tabInfo;
// 滑动控件
let scroller = document.getElementById("scroller");
let speed = scroller.scrollWidth / this.tabList.length;
let tab = document.getElementById(`tab-${id}`);
let bWidth = document.body.clientWidth;
// 点击右边
if (curTab.index < index && tab.clientWidth * index >= bWidth - speed) {
// 滑动的距离
scroller.scrollLeft = (index + 2) * speed - bWidth;
} else if (curTab.index > index && (tab.clientWidth * index - (scroller.scrollLeft + bWidth) < speed)) {
// 滑动的距离
scroller.scrollLeft = (index - 1) * speed;
}
curTab.select = false;
this.tabList[index].select = true;
}
}
}
less
.debug-index-page {
width: 100%;
overflow:hidden;
.tab-layout {
width: 100%;
overflow-x: scroll;
display: flex;
.tab-item {
width: 1rem;
text-align: center;
}
}
}
读到这里,这篇“vue怎么实现顶部左右滑动导航”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注亿速云行业资讯频道。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/u/4582201/blog/4378206