初探ant design pro
1.增加路由子页面&配置菜单
因为ant design pro采取的是umi路由配置,所以只要在对应的文件夹下新建相关的文件夹以及文件,它会自动解析。按照如下的步骤做即可


PS.如果想要给菜单配置icon,ant design pro有一些通用的icon图标,可以在上面配置路由的时候在每个路由处都加上 icon:'iconname' 即可,这是最简单的方法。
配置了路由以后再给它配置相关的语言预设即可,在这里我只配置了中文和英文。


这样页面上的菜单就会有相应的配置了。


2.使用mock模拟后台数据调用


在service里写相应的请求接口的逻辑,这里的request是ant design pro里自定义的接口请求方法,封装了fetch方法。

然后在相应的组件内建立models,触发action获得数据(这里用的是redux的思想)

完整的代码如下:
import { queryComment } from '@/services/geographic';
export default {
namespace: 'geographic', //命名空间,这里与组件里连接到模块的connect方法里的参数对应
state: {
comment:[],
isLoading: false,
},
//actions
effects: {
*fetchComment(_, { call, put }) {
//yield 关键字用来暂停和恢复一个生成器函数((function* 或遗留的生成器函数)。
yield put({
type: 'changeLoading',
payload: true,
});
const response = yield call(queryComment); //这里是请求到的数据
yield put({
type: 'setComment',
payload: Array.isArray(response) ? response : [],
});
yield put({
type: 'changeLoading',
payload: false,
});
},
},
//reducers指定了应用状态的变化如何响应actions并发送到store
reducers: {
setComment(state, action) {
return {
...state,
comment: action.payload,
};
},
changeLoading(state, action) {
return {
...state,
isLoading: action.payload,
};
},
},
};
在相应的组件中取相应的数据展示页面
import React, { Component } from 'react';
import {connect} from 'dva';
import {Table} from 'antd';
//取对应的模块
@connect(({geographic , loading }) => (
{
geographic ,
isLoading:loading.effects['geographic/fetchComment'],
}
))
export default class CommentManage extends Component{
componentDidMount(){
const {dispatch}=this.props;
//触发dispatch方法来触发action从而更改状态
dispatch({
type:'geographic/fetchComment'
})
}
handleChange=(current,pageSize)=>{
render(){
const columns = [
{
title: '姓名',
dataIndex: 'name',
key: 'name',
},
{
title: '所评文章ID',
dataIndex: 'article_id',
key: 'article_id',
},
{
title: '评论内容',
dataIndex: 'content',
key: 'content',
},{
title:'时间',
dataIndex:'create_by',
key:'create_by'
}];
const { isLoading } = this.props;
const {geographic:{comment}}=this.props;
const dataSource=[...comment];
// console.log(dataSource)
return (
<div>
<Table
bordered
dataSource={dataSource}
columns={columns}
size="small" />
</div>
)
}
}
然后页面上就能展示相应的数据了

在table表格里使用自定义的pagination,并且给每条数据加一个序号,详细代码如下:
//初始状态
state={
currentPage:1,
pageSize:16
} //页码跳转的回调函数
onCurrentChange=(current,pageSize)=>{ const {currentPage}=this.state;
//setState是异步执行的,给他加一个0的延时,可以立马执行
setTimeout(()=>{this.setState({currentPage:current});},0); }
//pageSize改变的回调
onShowSizeChange=(current,size)=>{
const {currentPage,pageSize}=this.state;
setTimeout(()=>{this.setState({currentPage:current,pageSize:size});},0);
} //render
const pagination={
pageSize:this.state.pageSize,
total:articles.length,
showSizeChanger:true,
pageSizeOptions:['8','10','16','32','48'],
onChange:this.onCurrentChange,
onShowSizeChange:this.onShowSizeChange,
showTotal:(total,range)=>`共 ${total} 条` } //columns里配置一行序号
{
title: '#',
key:'index',
// render:(text,record,index)=>`${index+1}`,这个方法当点击下一页时,其序号不连续,想用连续的需要用下面的方法
render(text,record,index){
return(
<div>
<span>{(currentPage-1)*pageSize+index+1}</span>
</div>
)
} }, //相应的table
<Table
bordered
dataSource={articles}
columns={columns}
size="small"
pagination={pagination}
/>
<Button>提交修改</Button>
</div>
初探ant design pro的更多相关文章
- Ant Design Pro+Electron+electron-builder实现React应用脱离浏览器,桌面安装运行
ant-design-pro ----> version :2.3.1 由于网上Ant Design Pro+Electron的资料太少,我就贡献一点经验 最近需要讲AntD Pro项目(以 ...
- 阿里开源项目之Ant Design Pro
本篇文章主要包含的内容有三个方面. 第一.Ant Design Pro简介; 第二.Ant Design Pro能做什么; 第三.初步使用; 我相信通过这三个方面的讲解能让你大概知道Ant Desig ...
- ant design pro (十五)advanced 使用 API 文档工具
一.概述 原文地址:https://pro.ant.design/docs/api-doc-cn 在日常开发中,往往是前后端分离的,这个时候约定好一套接口标准,前后端各自独立开发,就不会被对方的技术难 ...
- ant design pro (十四)advanced 使用 CLI 工具
一.概述 原文地址:https://pro.ant.design/docs/cli-cn 为了更好以及高效的开发效率,我们提供了配套的 ant-design-pro-cli 工具. pro cli 提 ...
- ant design pro (十三)advanced 错误处理
一.概述 原文地址:https://pro.ant.design/docs/error-cn 二.详细 2.1.页面级报错 2.1.1.应用场景 路由直接引导到报错页面,比如你输入的网址没有匹配到任何 ...
- ant design pro (十二)advanced UI 测试
一.概述 原文地址:https://pro.ant.design/docs/ui-test-cn UI 测试是项目研发流程中的重要一环,有效的测试用例可以梳理业务需求,保证研发的质量和进度,让工程师可 ...
- ant design pro (十一)advanced Mock 和联调
一.概述 原文地址:https://pro.ant.design/docs/mock-api-cn Mock 数据是前端开发过程中必不可少的一环,是分离前后端开发的关键链路.通过预先跟服务器端约定好的 ...
- ant design pro (十)advanced 图表
一.概述 原文地址:https://pro.ant.design/docs/graph-cn Ant Design Pro 提供了由设计师精心设计抽象的图表类型,是在 BizCharts 图表库基础上 ...
- ant design pro (八)构建和发布
一.概述 原文地址:https://pro.ant.design/docs/deploy-cn 二.详细 2.1.构建 当项目开发完毕,只需要运行一行命令就可以打包你的应用: npm run buil ...
随机推荐
- 「LuoguP3796」 【模板】AC自动机(加强版)
题目描述 有N个由小写字母组成的模式串以及一个文本串T.每个模式串可能会在文本串中出现多次.你需要找出哪些模式串在文本串T中出现的次数最多. 输入输出格式 输入格式: 输入含多组数据. 每组数据的第一 ...
- 面试题:sql数据查询
前几天参加一个面试,面试公司让做一套题,sql题不是很难,但是我第一次还是写错了,回来后,重新写了下.简单记录下吧, 1.题目: 2.测试数据 select * from student ; inse ...
- HTML学习笔记(六)TCP/IP
TCP/IP 是供已连接因特网的计算机进行通信的通信协议. 在 TCP/IP 中包含一系列用于处理数据通信的协议: TCP (传输控制协议) - 应用程序之间通信 UDP (用户数据包协议) - 应用 ...
- 初识btrace
此文已由作者易国强授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 1 btrace简介 BTrace是一个非常不错的java诊断工具.BTrace 中的B表示bytecode ...
- 使用Try.NET创建可交互.NET文档
原文地址:Create Interactive .NET Documentation with Try .NET 原文作者:Maria 译文地址:https://www.cnblogs.com/lwq ...
- MQ简介1
站在巨人的肩膀上 关于消息队列的使用 一.消息队列概述消息队列中间件是分布式系统中重要的组件,主要解决应用解耦,异步消息,流量削锋等问题,实现高性能,高可用,可伸缩和最终一致性架构.目前使用较多的消息 ...
- 单片机的C语言中位操作用法
在对单处机进行编程的过程中,对位的操作是经常遇到的.C51对位的操控能力是非常强大的.从这一点上,就可以看出C不光具有高级语言的灵活性,又有低级语言贴近硬件的特点.这也是在各个领域中都可以看到C的重要 ...
- D - Fliptile
#include <stdio.h> #include <iostream> #include <math.h> #include <algorithm> ...
- js_jquery
引用 jQuery 是一个 JavaScript 库,不需要安装,直接引用就行 <!-- jQuery --> <script src="/static/vendors/j ...
- Git本地分支与远程分支关联
当clone完版本库,切换到开发分支后,使用git pull -r 拉取并合并分支之后会出现一下提示: $ git pull -rFrom ssh://192.168.1.226:29418/etha ...