Ant Design Pro路由菜单

Posted xiaoyutongxue

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Ant Design Pro路由菜单相关的知识,希望对你有一定的参考价值。

config /config.js
配置list路由指向页面../layouts/NewPage

技术图片
import defaultSettings from ‘./defaultSettings‘; // https://umijs.org/config/

import slash from ‘slash2‘;
import webpackPlugin from ‘./plugin.config‘;
const  pwa, primaryColor  = defaultSettings; // preview.pro.ant.design only do not use in your production ;
// preview.pro.ant.design 专用环境变量,请不要在你的项目中使用它。

const  ANT_DESIGN_PRO_ONLY_DO_NOT_USE_IN_YOUR_PRODUCTION  = process.env;
const isAntDesignProPreview = ANT_DESIGN_PRO_ONLY_DO_NOT_USE_IN_YOUR_PRODUCTION === ‘site‘;
const plugins = [
  [
    ‘umi-plugin-react‘,
    
      antd: true,
      dva: 
        hmr: true,
      ,
      locale: 
        // default false
        enable: true,
        // default zh-CN
        default: ‘zh-CN‘,
        // default true, when it is true, will use `navigator.language` overwrite default
        baseNavigator: true,
      ,
      dynamicImport: 
        loadingComponent: ‘./components/PageLoading/index‘,
        webpackChunkName: true,
        level: 3,
      ,
      pwa: pwa
        ? 
            workboxPluginMode: ‘InjectManifest‘,
            workboxOptions: 
              importWorkboxFrom: ‘local‘,
            ,
          
        : false, // default close dll, because issue https://github.com/ant-design/ant-design-pro/issues/4665
      // dll features https://webpack.js.org/plugins/dll-plugin/
      // dll: 
      //   include: [‘dva‘, ‘dva/router‘, ‘dva/saga‘, ‘dva/fetch‘],
      //   exclude: [‘@babel/runtime‘, ‘netlify-lambda‘],
      // ,
    ,
  ],
  [
    ‘umi-plugin-pro-block‘,
    
      moveMock: false,
      moveService: false,
      modifyRequest: true,
      autoAddMenu: true,
    ,
  ],
]; // 针对 preview.pro.ant.design 的 GA 统计代码

if (isAntDesignProPreview) 
  plugins.push([
    ‘umi-plugin-ga‘,
    
      code: ‘UA-72788897-6‘,
    ,
  ]);
  plugins.push([
    ‘umi-plugin-pro‘,
    
      serverUrl: ‘https://ant-design-pro.netlify.com‘,
    ,
  ]);


export default 
  plugins,
  block: 
    // 国内用户可以使用码云
    // defaultGitUrl: ‘https://gitee.com/ant-design/pro-blocks‘,
    defaultGitUrl: ‘https://github.com/ant-design/pro-blocks‘,
  ,
  hash: true,
  targets: 
    ie: 11,
  ,
  devtool: isAntDesignProPreview ? ‘source-map‘ : false,
  // umi routes: https://umijs.org/zh/guide/router.html
  routes: [
    
      path: ‘/user‘,
      component: ‘../layouts/UserLayout‘,
      routes: [
        
          name: ‘login‘,
          path: ‘/user/login‘,
          component: ‘./user/login‘,
        ,
      ],
    ,
    
      path: ‘/‘,
      component: ‘../layouts/SecurityLayout‘,
      routes: [
        
          path: ‘/‘,
          component: ‘../layouts/BasicLayout‘,
          authority: [‘admin‘, ‘user‘],
          routes: [
            
              path: ‘/‘,
              redirect: ‘/welcome‘,
            ,
            
              path: ‘/welcome‘,
              name: ‘welcome‘,
              icon: ‘smile‘,
              component: ‘./Welcome‘,
            ,
            
              name: ‘table-list‘,
              path: ‘/list/table-list‘,
              component: ‘./list/table-list‘,
            ,
            
              name: ‘客户诉求‘,
              path: ‘/list‘,
              component: ‘../layouts/NewPage‘,
            ,
            
              component: ‘./404‘,
            ,
          ],
        ,
        
          component: ‘./404‘,
        ,
      ],
    ,
    
      component: ‘./404‘,
    ,
  ],
  // Theme for antd: https://ant.design/docs/react/customize-theme-cn
  theme: 
    ‘primary-color‘: primaryColor,
  ,
  define: 
    ANT_DESIGN_PRO_ONLY_DO_NOT_USE_IN_YOUR_PRODUCTION:
      ANT_DESIGN_PRO_ONLY_DO_NOT_USE_IN_YOUR_PRODUCTION || ‘‘, // preview.pro.ant.design only do not use in your production ; preview.pro.ant.design 专用环境变量,请不要在你的项目中使用它。
  ,
  ignoreMomentLocale: true,
  lessLoaderOptions: 
    javascriptEnabled: true,
  ,
  disableRedirectHoist: true,
  cssLoaderOptions: 
    modules: true,
    getLocalIdent: (context, _, localName) => 
      if (
        context.resourcePath.includes(‘node_modules‘) ||
        context.resourcePath.includes(‘ant.design.pro.less‘) ||
        context.resourcePath.includes(‘global.less‘)
      ) 
        return localName;
      

      const match = context.resourcePath.match(/src(.*)/);

      if (match && match[1]) 
        const antdProPath = match[1].replace(‘.less‘, ‘‘);
        const arr = slash(antdProPath)
          .split(‘/‘)
          .map(a => a.replace(/([A-Z])/g, ‘-$1‘))
          .map(a => a.toLowerCase());
        return `antd-pro$arr.join(‘-‘)-$localName`.replace(/--/g, ‘-‘);
      

      return localName;
    ,
  ,
  manifest: 
    basePath: ‘/‘,
  ,
  chainWebpack: webpackPlugin,
  
  proxy: 
    ‘/api‘: 
      target: ‘http://localhost:8080/santa‘,
      changeOrigin: true,
    ,
  ,
  
;
View Code

 

菜单生产两种方式:config.js自动生产和通过修改layouts/BasicLayout.jsx请求服务端获取菜单

以上是关于Ant Design Pro路由菜单的主要内容,如果未能解决你的问题,请参考以下文章

Ant Design Pro路由菜单

Ant Design Pro Vue使用心得

umi改为路由改为hash模式,Ant Design Pro Components的ProLayout 菜单不出来了

ant design pro 配置路由 显示页面步骤详解

ant-design-pro中菜单图标/业务组件,iconfont的使用

antd pro 动态菜单与动态路由