dva+umi+antd项目从搭建到使用
先创建一个新项目,具体步骤请参考https://www.cnblogs.com/darkbluelove/p/11338309.html
一.添加document.ejs文件(参考文档:https://umijs.org/zh/guide/app-structure.html#src-pages-document-ejs)
在pages文件夹下创建document.ejs文件,有这个文件时,会覆盖默认的 HTML 模板。
模板里需至少包含根节点的 HTML 信息 <div id="root"></div>
二.删除umirc.js文件(参考文档:https://umijs.org/zh/config/)
config/config.js 和 .umirc.js只能存在一个.所以我们删除.umirc.js文件,使用自己配置的config.js
在根目录创建config/config.js
config.js文件的具体配置可以查阅官方文档
config.js里面设置路由:
默认情况下,pages文件目录就是路由。配置的话需要在config.js里面,如下:(注意:component 是相对于 src/pages 目录的)
- export default {
- outputPath:'./content',
- treeShaking: true,
- ...
- history: 'hash', // 默认是 browser
- routes: [ // 自定义路由
- {
- title:'',
- path: '/',
- component:'./layouts/root',
- routes: [
- {
- title:'login',
- path: '/',
- component:'./login/login', //component 是相对于 src/pages 目录的
- },
- {
- path: '/manage', component: './layouts/manage',
- routes: [
- { path: '/manage', component: './manage/query',title:'首页' }
- ],
- }
- ]
- }
- ]
- }
三.添加模板文件夹layouts
删除根目录下的layouts文件夹,在pages文件夹下新增layouts文件夹,并且增加root.js和manage.js
root.js最外层的路由。manage.js是登陆有有导航菜单的路由
图一是默认的目录,图二是自定义后的目录:
图一 图二
使用的话就更简单了:
有如下目录pages/login.js,models/login.js
model/login.js代码如下:
- import { login } from '../services/query';
- import router from 'umi/router';
- export default {
- namespace: 'login', /// namespace 表示在全局 state 上的 key
- state: {
- userinfo:null
- },
- reducers: { //reducers 等同于 redux 里的 reducer,接收 action,同步更新 state
- suerinfoRenducers(state,{ payload }){
- return {
- ...state,
- userinfo:payload
- }
- }
- },
- effects:{
- * login({ payload }, { call, put, select }) {
- const response = yield call(login, payload?payload:'');
- yield put({
- type: 'suerinfoRenducers',
- payload:response
- })
- }
- }
- };
pages/login.js代码如下:
- import React from 'react';
- import style from './login.css';
- import { connect } from 'dva/index';
- class Login extends React.Component {
- login() {
- // 调用login命名空间下的login方法
- this.props.dispatch({
- type: 'login/login',
- payload: {},
- });
- }
- render() {
- return (
- <div className={style.login}>
- ...
- <button onClick={() => this.login()}>登陆</button>
- </div>
- );
- }
- }
- const mapStateUsers = (state) => {
- return {
- login: state.login, //这里的login表示后面用this.props.login获取state(根节点)中login命名空间(model的login.js中的state所有数据)的数据
- };
- };
- export default connect(mapStateUsers)(Login);
此时访问login页面,点击登陆按钮,就会出发login方法啦!
umi中使用loading:
@connect(({loading}) => ({ loading }))
添加了@connect(({loading}) => ({ loading })) 修饰器后,就打印出this.props就可以看到有loading了
effects下面就是对应的请求,(可以打印this.props.loading.effects['login/login']的值看下结果)
login/login发起请求的前this.props.loading.effects['login/login']的值为true,
login/login请求完成后this.props.loading.effects['login/login']的值就变为false
具体使用如下:
- ...
- import { Pagination,Spin,Alert } from 'antd';
- @connect(({loading}) => ({
- loading
- }))
- class Login extends React.Component {
- login() {
- // 调用login命名空间下的login方法
- this.props.dispatch({
- type: 'login/login',
- payload: {},
- });
- }
- render() {
- return (
- <div className={style.login}>
- <Spin spinning={this.props.loading.effects['login/login']}>
- <Alert
- message="Alert message title"
- description="Further details about the context of this alert."
- type="info"
- />
- </Spin>
- ...
- <button onClick={() => this.login()}>登陆</button>
- </div>
- );
- }
- }
- ...
好啦,就是这么简单!
dva+umi+antd项目从搭建到使用的更多相关文章
- dva+umi+antd项目从搭建到使用(没有剖验证,不知道在说i什么)
先创建一个新项目,具体步骤请参考https://www.cnblogs.com/darkbluelove/p/11338309.html 一.添加document.ejs文件(参考文档:https:/ ...
- dva+react+antd+webpack 项目开发配置
如何搭建一个dva项目如何搭建一个dva项目 后期项目会在github上进行书写,同时也会在segmentfault上进行同步-3Q拜读-
- typescript+react+antd基础环境搭建
typescript+react+antd基础环境搭建(包含样式定制) tsconfig.json 配置 // 具体配置可以看上面的链接 这里module moduleResolution的配置都会影 ...
- React全家桶打造共享单车后台管理系统项目_第1篇_项目环境搭建_首页编写
1.项目介绍 项目github地址:https://github.com/replaceroot/React-manageSystem 项目整体架构: 课程大纲: 第一章:React基础知识 ...
- dva + umi 学习笔记
首先,这里的 dva + umi 不是说学习dva和umi,而是基于 dva + umi 的react前端开发脚手架,这是我的目标. 一开始,我在dva文档的例子里看到了 dva + umi 的例子. ...
- Dva & Umi
Dva & Umi Dva.js & Umi.js React & Redux https://dvajs.com/ React and redux based, lightw ...
- Angular企业级开发(5)-项目框架搭建
1.AngularJS Seed项目目录结构 AngularJS官方网站提供了一个angular-phonecat项目,另外一个就是Angular-Seed项目.所以大多数团队会基于Angular-S ...
- 架构系列:ASP.NET 项目结构搭建
我们头开始,从简单的单项目解决方案,逐步添加业务逻辑的约束,从应用逻辑和领域逻辑两方面考虑,从简单的单个项目逐步搭建一个多项目的解决方案.主要内容:(1)搭建应用逻辑和领域逻辑都简单的单项目 (2)为 ...
- 国家电力项目SSH搭建
SSH项目框架搭建总结: 1.建立Web工程 * 导入需要的jar的包 db:连接数据库的驱动包 hibernate:使用hibernate的jar包 jstl:java的标准标签库 junit:测试 ...
随机推荐
- hive中时间操作(二)
转:https://blog.csdn.net/qq646748739/article/details/77997276 --Hive中日期函数总结:--1.时间戳函数--日期转时间戳:从1970-0 ...
- NSURLProtocol
An NSURLProtocol object handles the loading of protocol-specific URL data. @abstract This method reg ...
- 【转载】windbg 常用命令详解
windbg 常用命令详解 https://blog.csdn.net/chenyujing1234/article/details/7743460 vertarget 显示当前进程的大致信息 lmv ...
- 使用viper 进行golang 应用的配置管理
viper 是一个强大的golang 配置管理包,支持多种配置格式内容的读取,同时支持读取key/value 存储的数据 而且不只是读取内容 ,同时也包含了,配置的写入操作. 以下是一个简单的demo ...
- [RN] React Native 封装选择弹出框(ios&android)
之前看到react-native-image-picker中自带了一个选择器,可以选择拍照还是图库,但我们的项目中有多处用到这个选择弹出框,所以就自己写了一下,最最重要的是ios和Android通用. ...
- VUE的生命周期——钩子函数
- 数列分段II(信息学奥赛一本通 1436)(洛谷 1182)
[题目描述] 对于给定的一个长度为N的正整数数列A[i],现要将其分成M(M≤N)段,并要求每段连续,且每段和的最大值最小. 关于最大值最小: 例如一数列4 2 4 5 1要分成3段 将其如下分段: ...
- python 虚拟环境指定python版本
virtualenv --no-site-packages -p python3.7 testenv source testenv/bin/activate deactivate 参考:https:/ ...
- 学习HSDB
HSDB则是在SA(Serviceability Agent)基础上包装起来的一个调试器,而SA是个非常便于探索HotSpot VM内部实现的API. Stack Memory窗口的内容有三栏: 左起 ...
- Struts2工作原理和核心文件
一.Struts2工作原理 如下图: 二.Struts2配置文件 1.web.xml 任何MVC框架都需要与Web应用整合,这就不得不借助于web.xml文件,只有配置了web.xml文件的Servl ...