欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于Vue3+UniApp在單個頁面實(shí)現(xiàn)固定TabBar的多種方式

 更新時間:2025年03月21日 08:32:01   作者:碼農(nóng)研究僧  
tabBar 是移動端應(yīng)用常見的頁面效果,用于實(shí)現(xiàn)多頁面的快速切換,本文給大家介紹了如何基于Vue3+UniApp在單個頁面實(shí)現(xiàn)固定TabBar的多種方式,需要的朋友可以參考下

在 UniApp 開發(fā)中,tabBar 通常是通過 pages.json 配置的,適用于整個應(yīng)用的全局導(dǎo)航

然而,在某些場景下,我們可能需要只在特定的頁面展示 tabBar,而不會影響其他頁面的布局。這就需要使用 自定義 tabBar,可以通過 view 組件、uni-segmented-control 組件或 uni-nav-bar 組件等方式來實(shí)現(xiàn)

以下是幾種適用場景:

  • 局部頁面導(dǎo)航:
    例如,一個訂單管理頁面,用戶可以在 “進(jìn)行中” 和 “已完成” 之間切換,而不影響全局 tabBar

  • 底部固定的二級導(dǎo)航:
    例如,在 “記錄” 頁面,提供 “待審核” 和 “已審核” 選項(xiàng),方便用戶切換,而不會影響其他頁面

  • 頂部導(dǎo)航欄的切換:
    適用于不適合使用底部 tabBar 的場景,如數(shù)據(jù)管理頁面,用戶可以在 “待審核” 和 “已審核” 之間切換

方法適用場景說明
方法 1:自定義 view tabBar僅在某個頁面底部適用于特定頁面,不會影響全局 tabBar
方法 2:uni-segmented-control輕量級頁面切換適用于簡單的 Tab 選項(xiàng),不會影響布局
方法 3:uni-nav-bar頂部導(dǎo)航切換適用于帶頂部導(dǎo)航的 UI

1. 自定義 view

<template>
  <view class="container">


    <!-- 固定底部的 tabBar -->
    <view class="fixed-tabbar">
      <view class="tab-item" :class="{ active: currentTab === 0 }" @click="currentTab = 0">
        <text>測試A</text>
      </view>
      <view class="tab-item" :class="{ active: currentTab === 1 }" @click="currentTab = 1">
        <text>測試B</text>
      </view>
    </view>
  </view>
</template>

<script>
export default {
  data() {
    return {
      currentTab: 0, // 當(dāng)前選中的 tab
    };
  }
};
</script>

<style scoped>
.container {
  display: flex;
  flex-direction: column;
  height: 100vh;
}

.content {
  flex: 1;
  overflow-y: auto; /* 讓內(nèi)容可以滾動 */
  padding-bottom: 60px; /* 避免被底部 tabBar 遮擋 */
}

.fixed-tabbar {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 50px;
  display: flex;
  justify-content: space-around;
  align-items: center;
  background-color: #fff;
  border-top: 1px solid #ddd;
}

.tab-item {
  flex: 1;
  text-align: center;
  padding: 10px;
  font-size: 14px;
  color: #666;
}

.tab-item.active {
  color: #007AFF;
  font-weight: bold;
}
</style>

截圖如下:

fixed-tabbar 采用 position: fixed; bottom: 0;,始終固定在頁面底部
使用 currentTab 變量控制當(dāng)前選中的 tab,并根據(jù) active 類名高亮
padding-bottom: 60px; 避免頁面內(nèi)容被 tabBar 遮擋

2. uni-segmented-control

以輕量級方式切換不同的頁面內(nèi)容,不需要固定的底部 tabBar

<template>
  <view>
    <!-- 頂部 Tab 切換 -->
    <uni-segmented-control
      :current="currentTab"
      :values="['測試A', '測試B']"
      @clickItem="switchTab"
    />

    <!-- 提柜記錄 -->
    <view v-if="currentTab === 0">
      <uni-card title="測試A">
        <text>這里是測試A...</text>
      </uni-card>
    </view>

    <!-- 殘損單記錄 -->
    <view v-else>
      <uni-card title="測試B">
        <text>這里是測試B...</text>
      </uni-card>
    </view>
  </view>
</template>

<script>
export default {
  data() {
    return {
      currentTab: 0 // 默認(rèn)選中第一個
    };
  },
  methods: {
    switchTab(index) {
      this.currentTab = index;
    }
  }
};
</script>

截圖如下:

uni-segmented-control 提供頂部 tab,點(diǎn)擊時 @clickItem 觸發(fā) switchTab 進(jìn)行切換

僅 currentTab === 0 時展示

適用于無需固定底部導(dǎo)航欄的場景,如數(shù)據(jù)篩選切換

3. uni-nav-bar

頂部導(dǎo)航,在標(biāo)題欄左右提供不同的 Tab 切換按鈕

<template>
  <view>
    <!-- 自定義頂部 Tab -->
    <uni-nav-bar >
      <template v-slot:left>
        <view @click="switchTab(0)" :class="{ active: currentTab === 0 }">測試A</view>
      </template>
      <template v-slot:right>
        <view @click="switchTab(1)" :class="{ active: currentTab === 1 }">測試B</view>
      </template>
    </uni-nav-bar>

    <!-- 頁面內(nèi)容 -->
    <view v-if="currentTab === 0">
      <uni-card title="測試A">
        <text>這里是測試A...</text>
      </uni-card>
    </view>

    <view v-else>
      <uni-card title="測試B">
        <text>這里是測試B...</text>
      </uni-card>
    </view>
  </view>
</template>

<script>
export default {
  data() {
    return {
      currentTab: 0
    };
  },
  methods: {
    switchTab(index) {
      this.currentTab = index;
    }
  }
};
</script>

<style scoped>
.active {
  font-weight: bold;
  color: #007AFF;
}
</style>

uni-nav-bar 作為導(dǎo)航欄,在左右 slot 里添加點(diǎn)擊切換的按鈕。

switchTab 控制當(dāng)前顯示的內(nèi)容

以上就是基于Vue3+UniApp在單個頁面實(shí)現(xiàn)固定TabBar的多種方式的詳細(xì)內(nèi)容,更多關(guān)于Vue3 UniApp固定TabBar的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 關(guān)于VanCascader默認(rèn)值(地址code轉(zhuǎn)換)

    關(guān)于VanCascader默認(rèn)值(地址code轉(zhuǎn)換)

    這篇文章主要介紹了關(guān)于VanCascader默認(rèn)值(地址code轉(zhuǎn)換),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • Vue父子組件雙向綁定傳值的實(shí)現(xiàn)方法

    Vue父子組件雙向綁定傳值的實(shí)現(xiàn)方法

    父子組件之間的雙向綁定非常簡單,但是很多人因?yàn)槭菑腣ue 2+開始使用的,可能不知道如何雙向綁定,接下來通過本文給大家介紹Vue父子組件雙向綁定傳值的實(shí)現(xiàn)方法,需要的朋友可以參考下
    2018-07-07
  • Vue中key的作用及原理詳解

    Vue中key的作用及原理詳解

    本文主要介紹了Vue3中key的作用和工作原理,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 解決vue+router路由跳轉(zhuǎn)不起作用的一項(xiàng)原因

    解決vue+router路由跳轉(zhuǎn)不起作用的一項(xiàng)原因

    這篇文章主要介紹了解決vue+router路由跳轉(zhuǎn)不起作用的一項(xiàng)原因,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • vue測試環(huán)境打包與生產(chǎn)環(huán)境打包文件數(shù)量不一致解決方案

    vue測試環(huán)境打包與生產(chǎn)環(huán)境打包文件數(shù)量不一致解決方案

    這篇文章主要為大家介紹了vue測試環(huán)境打包與生產(chǎn)環(huán)境打包文件數(shù)量不一致的解決方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • vue中post請求報400的解決方案

    vue中post請求報400的解決方案

    這篇文章主要介紹了vue中post請求報400的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue整合百度地圖顯示指定地點(diǎn)信息

    vue整合百度地圖顯示指定地點(diǎn)信息

    本文主要介紹了vue整合百度地圖顯示指定地點(diǎn)信息,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • Vue+Element-ui表單resetFields無法重置問題

    Vue+Element-ui表單resetFields無法重置問題

    本文主要介紹了Vue+Element-ui表單resetFields無法重置問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • vue2+springsecurity權(quán)限系統(tǒng)的實(shí)現(xiàn)

    vue2+springsecurity權(quán)限系統(tǒng)的實(shí)現(xiàn)

    本文主要介紹了vue2+springsecurity權(quán)限系統(tǒng)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Vue 3.0 前瞻Vue Function API新特性體驗(yàn)

    Vue 3.0 前瞻Vue Function API新特性體驗(yàn)

    這篇文章主要介紹了Vue 3.0 前瞻Vue Function API新特性體驗(yàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08

最新評論