剧场模式
首页前后端分离ReactUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程

UmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #5 关于 footer 和 layout

想卖咖啡的程序员 · 元婴发布于新课程
0

https://pro.ant.design/docs/environment-variables-cn

https://umijs.org/zh/guide/env-variables.html#mock

https://umijs.org/zh/guide/app-structure.html#src

/**
 * Ant Design Pro v4 use `@ant-design/pro-layout` to handle Layout.
 * You can view component api by:
 * https://github.com/ant-design/ant-design-pro-layout
 */

import ProLayout, {
  MenuDataItem,
  BasicLayoutProps as ProLayoutProps,
  Settings,
  DefaultFooter,
} from '@ant-design/pro-layout';
import React, { useEffect } from 'react';
import Link from 'umi/link';
import { connect } from 'dva';
import { formatMessage } from 'umi-plugin-react/locale';

import Authorized from '@/utils/Authorized';
import RightContent from '@/components/GlobalHeader/RightContent';
import { ConnectState, Dispatch } from '@/models/connect';
import { isAntDesignPro } from '@/utils/utils';
import logo from '@/assets/logo.png';

export interface BasicLayoutProps extends ProLayoutProps {
  breadcrumbNameMap: {
    [path: string]: MenuDataItem;
  };
  settings: Settings;
  dispatch: Dispatch;
}
export type BasicLayoutContext = { [K in 'location']: BasicLayoutProps[K] } & {
  breadcrumbNameMap: {
    [path: string]: MenuDataItem;
  };
};

/**
 * use Authorized check all menu item
 */
const menuDataRender = (menuList: MenuDataItem[]): MenuDataItem[] =>
  menuList.map(item => {
    const localItem = {
      ...item,
      children: item.children ? menuDataRender(item.children) : [],
    };
    return Authorized.check(item.authority, localItem, null) as MenuDataItem;
  });

const links = [
  {
    key: 'qiuzhi99',
    title: 'qiuzhi99',
    href: 'https://pro.ant.design',
    blankTarget: true,
  },
  {
    key: 'Ant Design',
    title: 'Ant Design',
    href: 'https://ant.design',
    blankTarget: true,
  },
];

const copyright = '汕尾求知科技有限公司';

const footerRender: BasicLayoutProps['footerRender'] = (_, defaultDom) => {
  if (!isAntDesignPro()) {
    return (
      <>
        <DefaultFooter links={links} copyright={copyright} />
      </>
    );
  }
  return (
    <>
      {defaultDom}
      <div
        style={{
          padding: '0px 24px 24px',
          textAlign: 'center',
        }}
      >
        <a href="https://www.netlify.com" target="_blank" rel="noopener noreferrer">
          <img
            src="https://www.netlify.com/img/global/badges/netlify-color-bg.svg"
            width="82px"
            alt="netlify logo"
          />
        </a>
      </div>
    </>
  );
};

const BasicLayout: React.FC<BasicLayoutProps> = props => {
  const { dispatch, children, settings } = props;
  /**
   * constructor
   */

  useEffect(() => {
    if (dispatch) {
      dispatch({
        type: 'user/fetchCurrent',
      });
      dispatch({
        type: 'settings/getSetting',
      });
    }
  }, []);

  /**
   * init variables
   */
  const handleMenuCollapse = (payload: boolean): void =>
    dispatch &&
    dispatch({
      type: 'global/changeLayoutCollapsed',
      payload,
    });

  return (
    <ProLayout
      logo={logo}
      onCollapse={handleMenuCollapse}
      menuItemRender={(menuItemProps, defaultDom) => {
        if (menuItemProps.isUrl) {
          return defaultDom;
        }
        return <Link to={menuItemProps.path}>{defaultDom}</Link>;
      }}
      breadcrumbRender={(routers = []) => [
        {
          path: '/',
          breadcrumbName: formatMessage({
            id: 'menu.home',
            defaultMessage: 'Home',
          }),
        },
        ...routers,
      ]}
      itemRender={(route, params, routes, paths) => {
        const first = routes.indexOf(route) === 0;
        return first ? (
          <Link to={paths.join('/')}>{route.breadcrumbName}</Link>
        ) : (
          <span>{route.breadcrumbName}</span>
        );
      }}
      footerRender={footerRender}
      menuDataRender={menuDataRender}
      formatMessage={formatMessage}
      rightContentRender={rightProps => <RightContent {...rightProps} />}
      {...props}
      {...settings}
    >
      {children}
    </ProLayout>
  );
};

export default connect(({ global, settings }: ConnectState) => ({
  collapsed: global.collapsed,
  settings,
}))(BasicLayout);
4 条回复
  • netNowork · 大乘
    netNowork · 大乘 #1

    哦哦哦,来了来了, 学学学!

  • netNowork · 大乘
    netNowork · 大乘 #2
    /**
     * Ant Design Pro v4 use `@ant-design/pro-layout` to handle Layout.
     * You can view component api by:
     * https://github.com/ant-design/ant-design-pro-layout
     */
    import ProLayout, { DefaultFooter } from '@ant-design/pro-layout';
    // 用js的朋友需要注意一下这里可能跟用ts 的导入方式不同 在外部导入 , { DefaultFooter }
    
    import React, { useEffect, useState } from 'react';
    import Link from 'umi/link';
    import { connect } from 'dva';
    import { formatMessage } from 'umi-plugin-react/locale';
    import Authorized from '@/utils/Authorized';
    import RightContent from '@/components/GlobalHeader/RightContent';
    import { isAntDesignPro } from '@/utils/utils';
    import logo from '../assets/logo.png';
    
    // import { Icon, Layout } from 'antd';
    // import GlobalFooter from '@ant-design/pro-layout/lib/GlobalFooter';
    
    // const { Footer } = Layout;
    /**
     * use Authorized check all menu item
     */
    const menuDataRender = menuList =>
      menuList.map(item => {
        const localItem = { ...item, children: item.children ? menuDataRender(item.children) : [] };
        return Authorized.check(item.authority, localItem, null);
      });
    
    const defaultLinks = [
      {
        key: 'tile',
        title: 'tile',
        href: 'url',
        blankTarget: true,
      },
      {
        key: 'title',
        title: 'title',
        href: 'url',
        blankTarget: true,
      },
    ];
    const defaultCopyright = '写上你的footer';
    
    const footerRender = (_, defaultDom) => {
      if (!isAntDesignPro()) {
        return (
          <>
            <DefaultFooter
              links={defaultLinks} //进行绑定``` javascript
    
    
          copyright={defaultCopyright} //进行绑定
        />
      </>
    );
    

    }

    return (
    <>
    {defaultDom}





    </>
    );
    };

    const BasicLayout = props => {
    const { dispatch, children, settings } = props;
    /**

    • constructor */

    useEffect(() => {
    if (dispatch) {
    dispatch({
    type: 'user/fetchCurrent',
    });
    dispatch({
    type: 'settings/getSetting',
    });
    }
    }, []);
    /**

    • init variables */

    const handleMenuCollapse = payload =>
    dispatch &&
    dispatch({
    type: 'global/changeLayoutCollapsed',
    payload,
    });

    const [menuData, setMenuData] = useState([]);
    useEffect(() => {
    fetch('https://api.1km.im/jychannel/sel')
    .then(response => response.json())
    .then(data => {
    setMenuData(data.list || []);
    });
    }, []);

    return (
    {
    if (menuItemProps.isUrl) {
    return defaultDom;
    }

        return <Link to={menuItemProps.path}>{defaultDom}</Link>;
      }}
      breadcrumbRender={(routers = []) => [
        {
          path: '/',
          breadcrumbName: formatMessage({
            id: 'menu.home',
            defaultMessage: 'Home',
          }),
        },
        ...routers,
      ]}
      itemRender={(route, params, routes, paths) => {
        const first = routes.indexOf(route) === 0;
        return first ? (
          <Link to={paths.join('/')}>{route.breadcrumbName}</Link>
        ) : (
          <span>{route.breadcrumbName}</span>
        );
      }}
      footerRender={footerRender}
      menuDataRender={() => menuData}
      formatMessage={formatMessage}
      rightContentRender={rightProps => <RightContent {...rightProps} />}
      {...props}
      {...settings}
    >
      {children}
    </ProLayout>
    

    );
    };

    export default connect(({ global, settings }) => ({
    collapsed: global.collapsed,
    settings,
    }))(BasicLayout);

  • netNowork · 大乘
    netNowork · 大乘 #3

    上面是错误的 ❌,不用模仿了 导入的时候注意一下就好了,

  • Rong基 · 大乘
    Rong基 · 大乘 #4

    求教 左边栏的二级菜单再config.ts里面怎么配置啊

吐个槽
小程序(beta)
课程目录

1FreeUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #1 开始玩起来

2FreeUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #2 了解项目源码并尝试修改

3FreeUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #3 继续了解项目源码并修改代码

4FreeUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #4 如何修改 footer 及其原理

FreeUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #5 关于 footer 和 layout

6ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #6 如何好好利用 ant-design-pro-layout

7ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #7 如何下载和使用区块

8ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #8 为什么下载区块后会添加菜单

9ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #9 umi-plugin-pro-block-ts

10ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #10 删除国际化 i18n part 1

11ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #11 删除国际化 i18n part 2

12ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #12 用户注册的 block

13ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #13 让用户注册工作起来

14ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #14 注册的流程理解

15ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #15 准备好 API

16ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #16 对接好后端的注册功能

17ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #17 表单的前端验证与后端验证

18ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #18 后端的数据验证与前端的结合

19ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #19 自己写一个真实项目的注册页面 - 手机验证码 - 图形验证码

20ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #20 注册表单

21ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #21 表单与 TypeScript

22ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #22 注册表单 - connect - dispatch

23ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #23 实现注册功能并显示验证出错信息

24ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #24 详解注册页面手机验证码

25ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #25 注册页面手机验证码处理完成

26ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #26 手机验证码的原理(后端)

27ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #27 注册页面显示图形验证码

28ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #28 注册页面图形验证码的原理

29ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #29 注册页面提交失败时图形验证码重新刷新

30ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #30 注册页面成功跳转

31ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #31 用 localStorage 存储 jwt

32ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #32 重构代码,封装 request

33ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #33 登录页面

34ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #34 完成登录

35ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #35 登录权限验证 - 发送请求带上头信息

36ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #36 登录权限验证 - umi-request 异常处理程序

37ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #37 解决 umi-request 的 extend 关于 headers 的问题

38ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #38 显示个人用户信息

39ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #39 菜单权限控制显示

40ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #40 通过修改 getAuthority 方法利用 jwt 显示正确的菜单权限

41ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #41 刷新当前权限

42ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #42 其他的权限方法

43ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #43 权限验证的安全性(准备进入下一阶段)

44ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #44 实战 - 视频管理

45ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #45 实战 - 视频管理 - 视频列表

46ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #46 实战 - 视频管理 - 视频列表 - 发送请求获得远程的数据

47ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #47 实战 - 视频管理 - 视频列表 - 显示列表数据

48ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #48 实战 - 视频管理 - 视频列表 - 修复列表数据

49ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #49 实战 - 视频管理 - 视频列表 - 搜索列表

50ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #50 实战 - 视频管理 - 搜索 - 使用 qs 处理 umi-request 提交参数的问题

51ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #51 实战 - 视频管理 - 搜索 - 处理 moment 的时间问题

52ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #52 实战 - 视频管理 - 完成分页

53ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #53 实战 - 视频管理 - 添加视频

54ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #54 实战 - 视频管理 - 添加视频 - 发送请求

55ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #55 实战 - 视频管理 - 添加视频 - 处理完成

56ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #56 实战 - 视频管理 - 错误处理

57ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #57 实战 - 视频管理 - 详情页面

58ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #58 实战 - 视频管理 - 完成详情页面

59ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #59 实战 - 视频管理 - 删除视频

60ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #60 实战 - 视频管理 - 添加视频

61ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #61 实战 - 视频管理 - 添加视频 part 2

62ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #62 实战 - 视频管理 - 添加视频 part 3

63ProUmiJS & TypeScript & Ant Design Pro v4 从零开始实战教程 #63 完结

学员
fjp20312 · 元婴语 · 元婴小平头 · 元婴songtianen · 道祖志涛 · 真仙zhoumingxing · 元婴yichu2006 · 元婴🔆 · 金仙761698783 · 元婴海月明 · 元婴我去偷个柚子养你啊 · 真仙Rong基 · 大乘哒哒 · 元婴YJeremy · 真仙AphasiaPatient · 真仙ldc · 真仙NSN · 元婴MrXujiang · 元婴烂肉 · 真仙cvluca · 元婴Leon · 元婴ownryan · 道祖bibiehy · 元婴ligernkuan · 元婴xfgu · 合体Wwwwwwl · 大乘阿白 · 真仙zheng · 元婴三草 · 合体owenyikong · 大乘张杨 · 大乘cc20140820 · 真仙zhenwoo · 真仙贺方轩 · 元婴cocytus1223 · 太乙Sean · 元婴kimmerchen · 大罗React-小白 · 合体周超 · 元婴null · 真仙douyingying · 真仙frank · 真仙521707 · 元婴guowenzhuang · 元婴wanghuanhuai · 金仙隔壁小王 · 元婴xiao_ran · 太乙miss · 元婴448022914 · 元婴气体销售 · 太乙wuyanwen · 元婴Jesse · 大乘jhtinfo · 太乙莫名其妙 · 元婴DMAlexL · 合体ZQM · 元婴supergczh · 道祖Daniel · 元婴FTOLs · 元婴cometjun · 道祖怡 · 元婴kirito · 金仙Thever · 太乙葛绍飞 · 元婴靓狼仔 · 真仙星星De微光 · 合体iwell · 元婴刘浩 · 大乘lodash123 · 元婴wdahua · 元婴kongcheng · 金仙激战 · 合体Rocks · 大乘Mars.Liang · 大乘Ferris Xu · 太乙你坑到我了 · 太乙studytm · 金仙netzheng · 元婴Allen · 元婴skzhywgl · 元婴DERDRAGON · 元婴ZuhuaLiu · 元婴mfkyddh · 金仙哄哄 · 大乘quchenye · 元婴CCCpan · 元婴Zelo · 元婴zzqswo · 合体粽子 · 合体钟声 · 道祖shomychen · 元婴᭄᭄ꦿMars · 元婴wjfc · 太乙zc3130902 · 大罗ShuWangSam · 合体love309022 · 练虚刘小帅 · 元婴aaaaaa1 · 元婴金丹期,大成 · 大乘揣着明白、装糊涂 · 大乘柠檬GDM · 元婴阿飞 · 合体yudan215 · 元婴一棵柠檬红 · 元婴y · 元婴隐无为 · 元婴liulei-jishu · 合体Song-t · 元婴satos · 合体livend · 元婴capitalCodingguy · 元婴justice · 真仙gitliangying · 元婴这家伙真懒丶 · 真仙zhangxuanhtml5 · 元婴979164900 · 元婴guxiaobai · 道祖bluesky160 · 合体swdcode · 元婴szy0syz · 合体阿白 · 元婴pijunhuis · 大乘no_heart · 合体华仔 · 合体从前明月光 · 元婴qianyaqun · 元婴Ming · 真仙KaierChou · 太乙李忠 · 大乘oldtimestj · 合体yangy_11 · 合体winds · 合体deliphi · 元婴hanruiying · 道祖luz · 元婴李卓 · 元婴wlison123 · 元婴18361082737 · 金仙Jonathan · 元婴oldwolf · 元婴wlccgp3 · 元婴leeruigan · 合体Fu.H · 元婴尹迪 · 合体huangqiangqiang · 元婴꧁Cheri꧂ · 元婴     · 合体xawn10917 · 元婴itMyron · 道祖chaosJS · 元婴wjm0913 · 道祖yxxwym · 元婴漫长 · 大乘二木三水一州 · 元婴凉风ToT · 元婴范特西的范 · 元婴heiy · 太乙liuhao0813 · 元婴MDZZh · 元婴zenkun · 太乙qwer630701 · 元婴zhichaoren · 大罗yeziahehe · 元婴suheme · 元婴wuhua · 太乙shaohuatsou · 大乘Hichank · 元婴LeoDo · 太乙南国 · 元婴CRAZY · 元婴Sen0118 · 元婴lolotang · 元婴唐志龙 · 元婴netNowork · 大乘gangpu · 元婴
最新动态
fjp20312 · 元婴学习到了1:30
语 · 元婴学习到了7:27
小平头 · 元婴学习到了7:45
songtianen · 道祖学习到了7:45
志涛 · 真仙学习到了7:45

© 汕尾市求知科技有限公司 | 粤ICP备19038915号 | 在线学员:92

Top