UniApp配置tabBar

UniApp Tabbar

在Uniapp中,配置tabbar有两种方式:

第一种,通过UniApp自定义tabbar选项,配置对应的tab选项即可,

第二种,通过自定义tabbar实现

一 配置UniApp原生tabBar选项

1.1,配置pages页面

第一步,配置Pages.json里面的pages页面路由选项(必须先注册tabbar 对应的页面,不然会有不显示的问题)

json 复制代码
"pages": [
    //pages数组中第一项表示应用启动页,参考:https://uniapp.dcloud.io/collocation/pages
    {
      "path": "pages/index/index",
      "style": {
        "navigationBarTitleText": "首页",
        "navigationStyle": "custom"
      }
    },
    {
      "path": "pages/userCenter/index",
      "style": {
        "navigationBarTitleText": "个人中心"
      }
    }
  ],

1.2,配置pages.json里面的tabBar选项

json 复制代码
"tabBar": {
    "list": [
      {
        "pagePath": "pages/index/index",
        "iconPath": "static/home_icon.png",
        "selectedIconPath": "static/home_actived_icon.png",
        "text": "首页"
      },
      {
        "pagePath": "pages/userCenter/index",
        "iconPath": "static/usercenter_icon.png",
        "selectedIconPath": "static/usercenter_actived_icon.png",
        "text": "个人中心"
      }
    ]
  }

此刻,不出意外的话原生的tabBar就可以正常显示了,当然tabBar有很多的选项可以配置,颜色,图标啥的,请看官网的配置项目

二 配置自定义tabBar

这里通过uview-plus 组件库里面的 [up-tabbar](https://uiadmin.net/uview-plus/components/tabbar.html) 组件来实现, uview-plus也是可以实现多端的组件库,而且组件比较多,当然使用前要看一下每个组件的多端适配情况来决定的

2.1 自定义tabBar组件

js 复制代码
<template>
  <view class="">
    <up-tabbar :value="value2" :placeholder="false" @change="(name: number) => (value2 = name)" :fixed="true" :safeAreaInsetBottom="false">
      <up-tabbar-item text="首页" icon="home" dot></up-tabbar-item>
      <up-tabbar-item text="放映厅" icon="photo" badge="3"></up-tabbar-item>
      <up-tabbar-item text="直播" icon="play-right"></up-tabbar-item>
      <up-tabbar-item text="我的" icon="account"></up-tabbar-item>
    </up-tabbar>
  </view>
</template>

<script setup lang="ts">
  import { ref } from 'vue';

  const value2 = ref(1);
</script>

2.2 将自定义的组件在main.ts里面注册为全局组件,因为有很多的页面都需要显示(看需求,不需要则跳过)

直接在要使用的页面里面引入即可

讨论:

传统vue组件,需要安装、引用、注册,三个步骤后才能使用组件。easycom 将其精简为一步。只要组件安装在项目的components目录下或uni_modules目录下,并符合components/组件名称/组件名称.(vue|uvue)目录结构(注意:当同时存在vue和uvue时,uni-app 项目优先使用 vue 文件,而uni-app x 项目优先使用 uvue 文件,详情)。就可以不用引用、注册,直接在页面中使用, 可以通过easycom的custom配置tabbar。

但是配置了还是有点问题,如果大家有其他解决方案,可以评论区讨论一下

以上都是一些实现方案,如有错误,还请大家指正🙏

相关推荐
光影少年4 分钟前
前端线上出现白屏如何排查问题所在,利用第三方的工具都有哪些
前端·学习·web安全·前端框架
濑户川8 分钟前
Vue3 计算属性与监听器:computed、watch、watchEffect 用法解析
前端·javascript·vue.js
_Sem17 分钟前
KMP实战:从单端到跨平台的完整迁移指南
android·前端·app
Carry34520 分钟前
React 与 Vue 开发差异——CSS 样式
前端
前端九哥22 分钟前
我删光了项目里的 try-catch,老板:6
前端·vue.js
2301_7644413323 分钟前
身份证校验工具
前端·python·1024程序员节
4Forsee40 分钟前
【Android】View 事件分发机制与源码解析
android·java·前端
一 乐1 小时前
车辆管理|校园车辆信息|基于SprinBoot+vue的校园车辆管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·车辆管理
百锦再1 小时前
Python、Java与Go:AI大模型时代的语言抉择
java·前端·vue.js·人工智能·python·go·1024程序员节
IT_陈寒1 小时前
Vite 3.0终极提速指南:5个鲜为人知的配置技巧让构建效率翻倍
前端·人工智能·后端