在构建时是无法使用 dom 的,所以有些配置可能需要运行时来配置,一般而言我们都是在 src/app.tsx
中管理运行时配置。
getInitialState
用于获取初始化数据,初始化数据使用 useModel
在各个组件中使用,在请求中 getInitialState
会堵塞页面加载。
/*** @see https://umijs.org/zh-CN/plugins/plugin-initial-state* */export async function getInitialState(): Promise<{currentUser?: API.CurrentUser;}> {// 如果是登录页面,不执行const currentUser = await fetchUserInfo();return {currentUser,};}
initialStateConfig
是 getInitialState
的补充配置,getInitialState
支持异步的设置,在初始化没有完成之前我们展示了一个 loading,initialStateConfig
可以配置这个 loading。
/** 获取用户信息比较慢的时候会展示一个 loading */export const initialStateConfig = {loading: <PageLoading />,};
request
用于配置全局的网络请求,你可以在这里做拦截器,全局错误处理,鉴权的配置。
export const request: RequestConfig = {errorHandler: (error: ResponseError) => {const { messages } = getIntl(getLocale());const { response } = error;notification.error({description: '您的网络发生异常,无法连接服务器',message: '网络异常',});throw error;},};
在构建时是无法使用 dom 的,所以有些配置可能需要运行时来配置,我们可以在src/app.tsx
中 export 一个 layout
来进行配置:
import React from 'react';import { RunTimeLayoutConfig } from 'umi';import { BasicLayoutProps, Settings as LayoutSettings } from '@ant-design/pro-layout';// ProLayout 支持的api https://procomponents.ant.design/components/layoutexport const layout: RunTimeLayoutConfig = ({ initialState }) => {return {rightContentRender: () => <RightContent />,disableContentMargin: false,waterMarkProps: {content: initialState?.currentUser?.name,},footerRender: () => <Footer />,onPageChange: () => {console.log(location.pathname);},// 自定义 403 页面// unAccessible: <div>unAccessible</div>,...initialState?.settings,childrenRender: (children) => {return <div>{children}</div>;},};};
layout 支持一个 function,可以与 initialState
结合使用,将动态数据放入 initialState
中每次 initialState
变化都会触发更新。