Ant Design pro路由菜单标签页插件使用

安装命令

npm i umi-plugin-panel-tabs

在config/config.js文件下的definConfig方法中进行配置:

export default defineConfig({
  panelTab: {
    use404: true,
    useAuth: true,
    autoI18n: true,
    tabsLimit: 10,
    tabsLimitWait: 500,
    tabsLimitWarnTitle: '提示',
    tabsLimitWarnContent: '您当前打开页面过多, 请关闭不使用的页面以减少卡顿!',
    tabsBarBackgroundColor: '#FFFFFF',
    tabsTagColor: '#1890ff',
  },
});

在该路由中配置属性hideInPanelTab, 将其设置为true, 此路由就不会在标签页中显示

配置后标签栏位置出现了偏移?

在 app.jsx 的 layout 方法中添加 disableContentMargin: true 配置

或者

在global全局css中加入以下代码:
.ant-layout-content{
margin-top:0;
position: relative;
>div:first-child{
position:absolute;
left:0;
width:100%;
margin-left:208px;
height:50px;
}
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Ant Design Pro 是一个企业级的中后台前端/设计解决方案,它提供了丰富的组件和模板,使得开发者可以快速构建高质量的中后台应用。Ant Design Pro 中的动态路由菜单可以根据用户的权限动态生成菜单,从而提高应用的灵活性和实用性。 下面是实现 Ant Design Pro 动态路由菜单的步骤: 1. 在路由配置文件中设置动态路由: ``` const routerConfig = [ { path: '/home', component: './Home', routes: [ { path: '/home/page1', component: './Page1', name: 'Page1', authority: ['admin'], }, { path: '/home/page2', component: './Page2', name: 'Page2', authority: ['user'], }, ], }, ]; ``` 在上面的路由配置中,我们设置了两个子路由,分别是 `/home/page1` 和 `/home/page2`。除了设置路由的路径和组件之外,我们还设置了菜单的名称 `name` 和权限 `authority`。`authority` 属性用于控制该菜单项的显示权限,只有具备相应权限的用户才能看到该菜单项。 2. 在菜单配置文件中生成动态菜单: ``` const menuConfig = { routes: [ { path: '/home', name: 'Home', icon: 'home', authority: ['admin', 'user'], children: [ { path: '/home/page1', name: 'Page1', authority: ['admin'], }, { path: '/home/page2', name: 'Page2', authority: ['user'], }, ], }, ], }; ``` 在上面的菜单配置中,我们根据路由配置中设置的 `name` 和 `authority` 属性生成了动态菜单。如果用户具备相应的权限,他们就能看到对应的菜单项。 3. 在面中加载菜单组件: ``` import { getMenuData } from '@ant-design/pro-layout'; class Page extends React.Component { render() { const { routes } = this.props; const menuData = getMenuData(routes); return ( <div> <Menu theme="dark" mode="inline" defaultSelectedKeys={['1']}> {menuData.map(item => this.renderMenuItem(item))} </Menu> </div> ); } renderMenuItem(menuItem) { if (menuItem.children) { return ( <SubMenu key={menuItem.path} title={menuItem.name}> {menuItem.children.map(item => this.renderMenuItem(item))} </SubMenu> ); } else { return ( <Menu.Item key={menuItem.path}> <Link to={menuItem.path}>{menuItem.name}</Link> </Menu.Item> ); } } } ``` 在上面的代码中,我们使用 `getMenuData` 函数从路由配置文件中获取动态菜单数据,并使用 Ant Design Pro 的 `Menu` 组件渲染出菜单。如果菜单项包含子菜单项,我们使用 `SubMenu` 组件渲染子菜单,否则使用 `Menu.Item` 组件渲染菜单项。 通过以上步骤,我们就可以实现 Ant Design Pro 动态路由菜单了。通过设置路由配置文件和菜单配置文件,我们可以根据用户的权限动态生成菜单,从而提高应用的灵活性和实用性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值