基于vue框架怎样写顶部滑动导航,方法是什么
Admin 2022-07-11 群英技术资讯 1380 次浏览
关于“基于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)"
:style="`background:${tab.select ? 'red' : 'none'}`"
>
{{ 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;
}
}
}
以上就是导航的显示了。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
函数是一组执行特定任务(具有特定功能)的,可以重复使用的代码块。除了使用内置函数外,我们也可以自行创建函数(自定义函数),然后在需要的地方调用这个函数,这样不仅可以避免编写重复的代码,还有利于代码的后期维护。
本文主要介绍了浅谈JS数组内置遍历方法有哪些和区别,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
这篇文章主要为大家详细介绍了小程序实现上下切换位置,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
这篇文章主要为大家详细介绍了JS实现百度新闻导航栏效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
闭包在JavaScript高级程序设计(第3版)中是这样描述:闭包是指有权访问另一个函数作用域中的变量的函数,下面这篇文章主要给大家介绍了关于javascript解决闭包漏洞的一个问题的相关资料,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008