路由配置修改(五)

一、默认约定式路由

1、umi 会根据 pages 目录自动生成路由配置。
javascript 复制代码
 * @name umi 的路由配置
 * @description 只支持 path,component,routes,redirect,wrappers,name,icon 的配置
 * @param path  path 只支持两种占位符配置,第一种是动态参数 :id 的形式,第二种是 * 通配符,通配符只能出现路由字符串的最后。
 * @param component 配置 location 和 path 匹配后用于渲染的 React 组件路径。可以是绝对路径,也可以是相对路径,如果是相对路径,会从 src/pages 开始找起。
 * @param routes 配置子路由,通常在需要为多个路径增加 layout 组件时使用。
 * @param redirect 配置路由跳转
 * @param wrappers 配置路由组件的包装组件,通过包装组件可以为当前的路由组件组合进更多的功能。 比如,可以用于路由级别的权限校验
 * @param name 配置路由的标题,默认读取国际化文件 menu.ts 中 menu.xxxx 的值,如配置 name 为 login,则读取 menu.ts 中 menu.login 的取值作为标题
 * @param icon 配置路由的图标,取值参考 https://ant.design/components/icon-cn, 注意去除风格后缀和大小写,如想要配置图标为 <StepBackwardOutlined /> 则取值应为 stepBackward 或 StepBackward,如想要配置图标为 <UserOutlined /> 则取值应为 user 或者 User
 * @doc https://umijs.org/docs/guides/routes

其中针对多语言,name的应用相当关键。name 配置路由的标题,默认读取国际化文件 menu.ts 中 menu.xxxx 的值,如配置

name 为 login,则读取 menu.ts 中 menu.login 的取值作为标题

2、config/routes.ts、src/locales/zh-CN/menu.ts以及项目pages下文件结构需要一一对应
javascript 复制代码
export default [
  {
    path: '/user',
    layout: false,
    routes: [
      {
        name: 'login',
        path: '/user/login',
        component: './User/Login',
      },
    ],
  },
  {
    path: '/index',
    name: 'home',
    icon: 'smile',
    component: './home',
  },
  {
    path: '/func',
    name: 'func',
    icon: 'crown',
    access: 'canAdmin',
    routes: [
      {
        path: '/func',
        redirect: '/func/funcManage',
      },
      {
        path: '/func/funcManage',
        name: 'funcManage',
        component: './funcManage',
      },
    ],
  },
  {
    name: 'userManage',
    icon: 'table',
    path: '/userManage',
    component: './userManage',
  },
  {
    path: '/',
    redirect: '/index',
  },
  {
    path: '*',
    layout: false,
    component: './404',
  },
];
javascript 复制代码
export default {
  'menu.home': '首页',
  'menu.func': '功能管理',
  'menu.func.funcManage': '功能管理',
  'menu.userManage': '用户管理',
  'menu.login': '登录',
  'menu.register': '注册'
}

最终呈现效果就是自定义的一样

3、首页/index
4、功能管理/func/funcManage
5、功能管理/userManage
相关推荐
张拭心4 分钟前
春节后,有些公司明确要求 AI 经验了
android·前端·人工智能
时光不负努力4 分钟前
typescript常用的dom 元素类型
前端·typescript
小怪点点10 分钟前
大文件切片上传
前端
时光不负努力10 分钟前
TS 常用工具类型
前端·javascript·typescript
SuperEugene12 分钟前
Vue状态管理扫盲篇:Vuex 到 Pinia | 为什么大家都在迁移?核心用法对比
前端·vue.js·面试
张拭心14 分钟前
Android 17 来了!新特性介绍与适配建议
android·前端
徐小夕19 分钟前
pxcharts-vue:一款专为 Vue3 打造的开源多维表格解决方案
前端·vue.js·github
Hilaku19 分钟前
我会如何考核一个在简历里大谈 AI 提效的高级前端?
前端·javascript·面试
青青家的小灰灰41 分钟前
React 反模式(Anti-Patterns)排查手册:从性能杀手到逻辑陷阱
前端·javascript·react.js
青青家的小灰灰41 分钟前
告别 Prop Drilling:Context API 的陷阱、Reducer 模式与原子化状态库原理
前端·javascript·react.js