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,
    },
  },

};

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

原文地址:https://www.cnblogs.com/xiaoyutongxue/p/11408740.html

时间: 2024-10-29 02:19:47

Ant Design Pro路由菜单的相关文章

[原创]React+Ant Design设置左侧菜单导航路由的显示与隐藏(与权限无关)

最近在学习react时,用到了很流行的UI框架Ant Design,也了解了一下Ant Design Pro,发现它们都有导航组件,Ant Design框架的导航菜单在这里,Ant Design Pro是权限菜单,权限菜单简单来说就是根据登录的权限来展示不同的菜单给用户,比如管理员有给用户分配不同角色的权限,那管理员就可以看到系统管理等导航菜单,而用户A只有发布某些业务的权限,那用户A就不能看到系统管理的导航菜单等等.不过这不在我们本文的考虑范围内,有兴趣的同学可以自行去看它的API:Autho

SpringBoot整合Ant Design Pro进行部署

一.Ant Design Pro 打包 1.1 运行 build打包 $ npm run build 1.2 将打包生成的静态文件拷贝到spring boot 项目中 构建打包成功之后,会在根目录生成 dist 文件夹,然后将dist 文件夹里的的文件复制到 spring boot 项目的 /src/main/resources/static 目录下 二.配置spring boot 项目可访问到static目录下的index.html 2.1 以gradle为例导入spring-boot-sta

ant design pro (十二)advanced UI 测试

一.概述 原文地址:https://pro.ant.design/docs/ui-test-cn UI 测试是项目研发流程中的重要一环,有效的测试用例可以梳理业务需求,保证研发的质量和进度,让工程师可以放心的重构代码和新增功能. Ant Design Pro 封装了一套简洁易用的 React 单元测试和 E2E 测试方案,在项目根目录运行以下命令就能运行测试用例. npm run test:all # 执行所有测试 二.详细 2.1.单元测试 单元测试用于测试 React UI 组件的表现.我们

ant design pro (十四)advanced 使用 CLI 工具

一.概述 原文地址:https://pro.ant.design/docs/cli-cn 为了更好以及高效的开发效率,我们提供了配套的 ant-design-pro-cli 工具. pro cli 提供了如下功能: pro new 新建一个脚手架,会自动将最新的 Ant Design Pro 脚手架下载到本地并安装 pro generate 新建一个模板,包含 model.service.page.component 二.使用过程 2.1.如何使用 使用 npm 安装到本地 npm instal

Ant Design Pro 中的服务端交互

前端请求流程 在 Ant Design Pro 中,一个完整的前端 UI 交互到服务端处理流程是这样的: UI 组件交互操作: 调用 model 的 effect: 调用统一管理的 service 请求函数: 使用封装的 request.js 发送请求: 获取服务端返回: 然后调用 reducer 改变 state: 更新 model 统一的请求处理都放在 services 文件夹中,并且一般按照 model 维度进行拆分文件 services/ user.js api.js ... 其中,ut

Nginx 部署 Ant Design pro

利用Ant Design pro开发的项目,如何用Nginx部署呢? 第一步:把项目打包,打包命令如下: npm run build 运行完毕会在项目目录下生成dist文件夹. 第二步:想要测试打包好的代码是否可以正常运行,安装serve,如下命令 npm i serve -g serve安装完毕,利用serve运行打包好的代码,运行命令: serve dist 测试完毕,代码可以正常运行. 第三步:用Nginx进行部署. 1.下载Nginx:http://nginx.org/en/downlo

如何创建Pull Request,以开源项目ant design pro为例

声明:本文章也是我本人参考网络上的一些教程写的,毕竟我也是第一次为开源项目做贡献,心里难免有点小激动.所以用此文章来记录这个过程,和一些操作方式.同时留作以后可供参考. 背景:最近做了公司一个项目,具体项目我也就不说了,反正用了React+Umi+Ant Design Pro.具体情况是这样,使用官方的SettingDrawer实现了在线切换主题的功能,但是官方的控件中会有如下拷贝设置按钮一直显示. 然而我想要的效果如右图 可是我的项目上线后,不需要复制主题配置进行分享,仅开发过程中设置默认主题

003-ant design pro 路由和菜单

一.概述 参看地址:https://pro.ant.design/docs/router-and-nav-cn 二.原文摘要 路由和菜单是组织起一个应用的关键骨架,我们的脚手架提供了一些基本的工具及模板,帮助你更方便的搭建自己的路由/菜单. 如果你想了解更多关于 browserHistory 和 hashHistory,请参看 构建和发布. 注意:我们的脚手架依赖 [email protected],路由方面是基于 [email protected] 的实现,在写法以及 API 上与之前的版本有

实战 ant design pro 中的坑

1.前戏: 1,替换mock数据: 1.将:.roadhogrc.mock.js 中的代理模式替换 当不使用代理的时候就会将所有 /api/*的链接换成 http://localhost:8080/ export default noProxy ? {'GET /api/*':'http://localhost:8080/'} : delay(proxy, 1000); 2.启动: window:npm run start:no-proxy 其他系统没试 坑 1. what?这是什么鬼没设置ke