uniapp 自定义写底部导航栏

项目的需求是根据用户的权限判断,当前显示哪些菜单。

项目使用uniapp + vue3.0

1 根据前端写的项目目录来判断当前返回的路由是否有相同的,因为是数组所以做了封装函数来判断当前的路由数组。

javascript 复制代码
//函数封装
function resArr(arr1, arr2) {
    const appTabs = [];
    arr1.forEach(v => {
        arr2.forEach(val => {
            if (val.path == v.pagePath) appTabs.push(v);
        });
    });

    return appTabs;
}

2 数组路由当然少不了组件,vue3.0 的组件引入方式修改了,不再使用components ,需要在引入的地方导入组件,

shallowRef:只处理基本数据类型的响应式, 不进行对象的响应式处理,直接使用组件浏览器会报警告

javascript 复制代码
import Order from '@/pages/order/order.vue';


{
        name: shallowRef(Order),
        pagePath: '../order/order',
        iconPath: '/static/tabbar/torder.png',
        selectedIconPath: '/static/tabbar/torder_c.png',
        text: '订单'
    },


 <component :is="data.getItem.name"></component>

3 写底部导航的样式应该很简单了把

相关推荐
许彰午2 分钟前
12_ArrayList与LinkedList深度对比
java·前端·python
lichenyang45319 分钟前
鸿蒙练习 12:Provider/Consumer 跨层共享 + HAR 多模块拆分
前端
朱涛的自习室26 分钟前
逃离“古法测试”:AI 测试的“三大定律”
android·前端·人工智能
糖果店的幽灵27 分钟前
Claude Code 完全实战指南 - 第二章:CLI 命令大全
前端·chrome
ZC跨境爬虫1 小时前
跟着 MDN 学CSS day_45:媒体查询入门指南——从语法到移动优先实践
前端·css·ui·html·tensorflow·媒体
Geek_Vison1 小时前
技术实践:保险健康APP引入第三方小程序实战,如何构建一个安全可控的沙箱环境~
android·安全·小程序·uni-app·mpaas
Hoey1 小时前
虚拟 DOM 和 DIFF 算法
前端·vue.js
bkspiderx1 小时前
HTTP协议:Web通信的“通用语言”解析
前端·网络协议·http
云水一下1 小时前
模块系统与 npm——万物皆模块
前端·npm·node.js
ZC跨境爬虫2 小时前
跟着 MDN 学CSS day_47:(移动优先实战——从手机到宽屏的响应式进化)
前端·css·html·tensorflow·媒体