基于umi搭建一个快速开发框架,react 应用框架。umi 以路由为基础的,支持类 next.js 的约定式路由,以及各类进阶的路由功能,并以此进行功能扩展,好比支持路由级的按需加载。
咱们会在基于umi的基础上,开发出一个框架通用功能和业务功能
框架功能列表css
业务功能html
umi 提供了脚手架供咱们快速建立项目。参考umi脚手架建立项目
包管理器咱们推荐用yarn来替换npm,yarn在包安装速度上确实提高很多react
1.在你的空目录下执行,git
yarn create umi 咱们须要选择 antd,code splitting, dll, hard source
2.安装依赖github
yarn
3.启动本地开发npm
yarn start
umi规定 src/layouts
目录下存放咱们全局layout组件, 在index.js中加入代码以下浏览器
class BaseLayout extends React.Component { state = { collapsed: false, }; onCollapse = (collapsed) => { console.log(collapsed); this.setState({ collapsed }); } render() { return ( <Layout style={{ minHeight: '100vh' }}> <Sider collapsible collapsed={this.state.collapsed} onCollapse={this.onCollapse} > <div className={styles.logo} /> <MenuComponent /> </Sider> <Layout> <Header style={{ background: '#fff', padding: 0 }} /> <Content style={{ margin: '0 16px' }}> <Breadcrumb style={{ margin: '16px 0' }}> <Breadcrumb.Item>User</Breadcrumb.Item> <Breadcrumb.Item>Bill</Breadcrumb.Item> </Breadcrumb> <div style={{ padding: 24, background: '#fff', minHeight: 360 }}> {this.props.children} </div> </Content> <Footer style={{ textAlign: 'center' }}> Ant Design ©2018 Created by Ant UED </Footer> </Layout> </Layout> ); } } export default BaseLayout;
layout 组件须要 MenuComponent
,
在构建组件以前咱们须要先mock菜单数据,umi支持mock,咱们在mock文件下添加 auth.jsantd
const menu = [ { id: 1, name: '概览', icon: 'dashboard', url: '/dashboard', }, { id: 2, name: '系统管理', icon: 'setting', url: '/system', children: [ { id: 21, name: '用户管理', icon: 'user', url: '/system/user', } ] }, ];
menu数据是树形结构,在项目当中,能够构造放到前台,也可让后台小伙伴们返回。比较灵活,咱们基于数据去作渲染就行。
还有一个很重要的概念,umi也集成了dva,咱们的src/models
路径下添加auth.js的以下。app
import { getMenu } from '../services/auth'; export default { namespace: 'auth', state: { menu: [] }, effects: { *getMenu(_, { put, select, call }) { const menu = yield call(getMenu); yield put({ type: 'setMenu', payload: menu, }); }, }, reducers: { setMenu(state, { payload }) { return { ...state, menu: payload, }; }, }, };
基础工做已经完成。就能够来构建MenuComponent组件。框架
@connect(({auth}) => { return { menu: auth.menu, } }) class MenuComponent extends React.Component { componentDidMount() { // 获取 menu 数据 this.props.dispatch({ type: 'auth/getMenu', }) } link = (url) => { router.push(url); } renderMenu = (data) => { return data && data.map(d => { if (d.children && d.children.length > 0) { return <SubMenu key={d.id} title={<span><Icon type={d.icon} /><span>{d.name}</span></span>} > {this.renderMenu(d.children)} </SubMenu> } return ( <Menu.Item key={d.id} onClick={() => {this.link(d.url)}} > <Icon type={d.icon} /> <span>{d.name}</span> </Menu.Item> ) }); } render() { const { menu } = this.props; return ( <Menu theme='dark' defaultSelectedKeys={['1']} mode='inline'> { this.renderMenu(menu) } </Menu> ); } } export default MenuComponent;
总的来讲,menu组件会访问会调用saga effect,发出异步请求获取数据,而后经过dva connect获取menu数据作渲染。
咱们刷新浏览器看到菜单已经正确渲染了。
这是开始的第一步,也欢迎你们监督,接下来会逐步把上面提到的功能完善起来。代码已放到github上,你们能够自行查看umi-react。
我建了一个QQ群,你们加进来,能够一块儿交流。群号 787846148