vue實(shí)現(xiàn)頂部左右滑動(dòng)導(dǎo)航
日常開(kāi)發(fā)中經(jīng)常用到導(dǎo)航這些東西,寫(xiě)篇文章記錄下。該導(dǎo)航實(shí)現(xiàn)為點(diǎn)擊末尾/起首位置,導(dǎo)航自動(dòng)滑動(dòng)出下一項(xiàng)的效果。
思路:判斷當(dāng)前點(diǎn)擊項(xiàng),相對(duì)與屏幕的位置,若點(diǎn)擊的位置,滿足可移動(dòng)的限制,進(jìn)行自動(dòng)滑動(dòng)處理。
實(shí)現(xiàn)如下:
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標(biāo)識(shí)
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;
// 滑動(dòng)控件
let scroller = document.getElementById("scroller");
let speed = scroller.scrollWidth / this.tabList.length;
let tab = document.getElementById(`tab-${id}`);
let bWidth = document.body.clientWidth;
// 點(diǎn)擊右邊
if (curTab.index < index && tab.clientWidth * index >= bWidth - speed) {
// 滑動(dòng)的距離
scroller.scrollLeft = (index + 2) * speed - bWidth;
} else if (curTab.index > index && (tab.clientWidth * index - (scroller.scrollLeft + bWidth) < speed)) {
// 滑動(dòng)的距離
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;
}
}
}
以上就是導(dǎo)航的顯示了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Vue實(shí)現(xiàn)tab導(dǎo)航欄并支持左右滑動(dòng)功能
- vue實(shí)現(xiàn)左右滑動(dòng)效果實(shí)例代碼
- vue+swiper實(shí)現(xiàn)左右滑動(dòng)的測(cè)試題功能
- vue使用swiper實(shí)現(xiàn)左右滑動(dòng)切換圖片
- vue使用better-scroll實(shí)現(xiàn)滑動(dòng)以及左右聯(lián)動(dòng)
- vue移動(dòng)端的左右滑動(dòng)事件詳解
- vue移動(dòng)端實(shí)現(xiàn)手機(jī)左右滑動(dòng)入場(chǎng)動(dòng)畫(huà)
- Vue實(shí)現(xiàn)移動(dòng)端左右滑動(dòng)效果的方法
- 基于Vue實(shí)現(xiàn)頁(yè)面切換左右滑動(dòng)效果
- Vue可左右滑動(dòng)按鈕組組件使用詳解
相關(guān)文章
Vue通過(guò)moment插件實(shí)現(xiàn)獲取當(dāng)前月的第一天和最后一天
這篇文章主要介紹了Vue 結(jié)合插件moment 實(shí)現(xiàn)獲取當(dāng)前月的第一天和最后一天,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-10-10
使vue實(shí)現(xiàn)jQuery調(diào)用的兩種方法
這篇文章主要介紹了使vue實(shí)現(xiàn)jQuery調(diào)用的兩種方法 ,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05
vue動(dòng)態(tài)循環(huán)出的多個(gè)select出現(xiàn)過(guò)的變?yōu)閐isabled(實(shí)例代碼)
本文通過(guò)實(shí)例代碼給大家分享了vue動(dòng)態(tài)循環(huán)出的多個(gè)select出現(xiàn)過(guò)的變?yōu)閐isabled效果,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2019-11-11
Vue組件化開(kāi)發(fā)之通用型彈出框的實(shí)現(xiàn)
這篇文章主要介紹了Vue組件化開(kāi)發(fā)之通用型彈出框的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
vuex項(xiàng)目中登錄狀態(tài)管理的實(shí)踐過(guò)程
由于狀態(tài)零散地分布在許多組件和組件之間的交互中,大型應(yīng)用復(fù)雜度也經(jīng)常逐漸增長(zhǎng),為了解決這個(gè)問(wèn)題,Vue 提供 vuex,這篇文章主要給大家介紹了關(guān)于vuex項(xiàng)目中登錄狀態(tài)管理的相關(guān)資料,需要的朋友可以參考下2021-09-09
Vue3新?tīng)顟B(tài)管理工具實(shí)例詳解
Vue3公布曾經(jīng)有一段時(shí)間了,它采納了新的響應(yīng)式零碎,而且構(gòu)建了一套全新的 Composition API,下面這篇文章主要給大家介紹了關(guān)于Vue3新?tīng)顟B(tài)管理工具的相關(guān)資料,需要的朋友可以參考下2022-03-03
vue文本識(shí)別"\n"換行問(wèn)題的解決方式
在頁(yè)面中經(jīng)常會(huì)遇到自定義文本,如果文本過(guò)長(zhǎng)就需要換行,在HTML中可以通過(guò)標(biāo)簽換行,也可以通過(guò)\n轉(zhuǎn)椅字符換行,下面這篇文章主要給大家介紹了關(guān)于vue文本識(shí)別“\n”換行問(wèn)題的解決方式,需要的朋友可以參考下2022-11-11
vue組件傳遞對(duì)象中實(shí)現(xiàn)單向綁定的示例
下面小編就為大家分享一篇vue組件傳遞對(duì)象中實(shí)現(xiàn)單向綁定的示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02

