1.页面的结构

  1. //遍历list, 返回数据
  2.       let listBody= this.state.list.map((user,index)=> {
  3.           return (
  4.            <tr key={index}>
  5.              <td>{user.id}</td>
  6.              <td>{user.username}</td>
  7.              <td>{user.email}</td>
  8.              <td>{user.phone}</td>
  9.              <td>{new Date(user.createTime).toLocaleString()}</td>
  10.          </tr>
  11.        )
  12.       });
  13.       //当this.state.list.length<=0,第一次加载的时候firstLoading=true,显示"正在加载数据"
  14.       //当this.state.list.length<=0,第一次加载的时候firstLoading=false,显示"正在加载数据"
  15.       let listError=(
  16.           <tr>
  17.               <td colSpan="" className="text-center">
  18.                 {this.state.firstLoading ?"正在加载数据....." : "没有找到相应的结果"}
  19.               </td>
  20.           </tr>
  21.       )
  22.       let tableBody=this.state.list.length > 0 ? listBody:listError;
  23.      return (
  24.         <div id="page-wrapper">
  25.               <PageTitle title="用户列表"/>
  26.               <div className="row">
  27.                   <table className="table table-striped table-bordered">
  28.                       <thead>
  29.                           <tr>
  30.                               <th>ID</th>
  31.                               <th>用户名</th>
  32.                               <th>邮箱</th>
  33.                               <th>电话</th>
  34.                               <th>注册时间</th>
  35.                           </tr>
  36.                       </thead>
  37.                       <tbody>
  38.                           {
  39.                             tableBody
  40.                           }
  41.                       </tbody>
  42.                   </table>
  43.               </div>
  44.               {/* 分页组件 */}
  45.               <Pagination current={this.state.pageNum}
  46.               total={this.state.total}
  47.               onChange={(pageNum) => {this.onPageNumChange(pageNum)}}/>
  48.         </div>
  49.      );

2.用户列表接口/manage/user/list.do ,请求数据为,pageNum和pageSize, pageSize默认为10,所以只需要传入当前页pageNum就可以了

  1. this.state={
  2.            list:[],
  3.            pageNum:1,
  4.            //判断是不是第一次加载
  5.            firstLoading:true
  6.        }

请求后台数据

  1. //当页码挂载之后请求数据
  2.     componentDidMount(){
  3.        this.loadUserList();
  4.     }
  1. loadUserList(){
  2.        _user.getUserList(this.state.pageNum).then(res => {
  3.            //res替换了state
  4.            this.setState(res,() => {
  5.                //第一次加载的时候把firstLoading设置为false
  6.                this.setState({
  7.                   firstLoading:false
  8.                })
  9.            });
  10.        },errMsg =>{
  11.             this.setState({
  12.                 list : []
  13.             });
  14.             _mm.errorTips(errMsg);
  15.        })
  16.     }

3.当页码改变的时候触发onChange事件,调用onPageNumChange函数,传入当前页pageNum,更新state里边的pageNum

  1. //当页数变化的时候改变pageNum
  2.  onPageNumChange(pageNum){
  3.      //setSate是个异步函数
  4.      this.setState({
  5.          pageNum : pageNum
  6.      },() => {
  7.          //当页码更新了重新请求每页的记录,后台返回数据是根据页码返回的
  8.          this.loadUserList();
  9.      })
  10.  }

React后台管理系统-用户列表页面的更多相关文章

  1. React后台管理系统-商品列表搜索框listSearch组件

    1.商品列表搜索框 2.搜索框页面的结构为 <div className="row search-wrap">               <div classN ...

  2. React后台管理系统-table-list组件

    table-list组件可用于商品列表,用户列表页面 需要传入一个tableHeads集合和tablebody import React from 'react';   // 通用的列表 class ...

  3. React后台管理系统- rc-pagination分页组件封装

    1.用户列表页面使用的rc-pagination分页组件 Github地址: https://github.com/react-component/pagination 2.安装 cnpm insta ...

  4. 《React后台管理系统实战 :一》:目录结构、引入antd、引入路由、写login页面、使用antd的form登录组件、form前台验证、高阶函数/组件

    实战 上接,笔记:https://blog.csdn.net/u010132177/article/details/104150177 https://gitee.com/pasaulis/react ...

  5. 《React后台管理系统实战 :二》antd左导航:cmd批量创建子/目录、用antd进行页面布局、分离左导航为单独组件、子路由、动态写左导航、css样式相对陷阱

    一.admin页面布局及路由创建 0)cmd批量创建目录及子目录 //创建各个目录,及charts和子目录bar md home category product role user charts\b ...

  6. React后台管理系统-商品管理列表组件

    1.商品列表页面结构 <div id="page-wrapper">              <PageTitle title="商品列表" ...

  7. react后台管理系统路由方案及react-router原理解析

        最近做了一个后台管理系统主体框架是基于React进行开发的,因此系统的路由管理,选用了react-router(4.3.1)插件进行路由页面的管理配置. 实现原理剖析 1.hash的方式   ...

  8. 【共享单车】—— React后台管理系统开发手记:主页面架构设计

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

  9. 【共享单车】—— React后台管理系统开发手记:Router 4.0路由实战演练

    前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...

随机推荐

  1. jdk的卸载

    问题描述: win10环境安装了jdk1.7&jdk1.8&jdk1.9 jdk1.9安装后,设置jdk1.9安装目录为JAVA_HOME.后来JAVA_HOME切换jdk1.8环境变 ...

  2. 《SQL 进阶教程》 自连接分组排序:练习题1-2-2

    分组排序 SELECT d1.district, d1. NAME, (SELECT COUNT(d2.price) FROM district_products d2 WHERE d2.price ...

  3. gulp的watch记事本

    let gulp=require('gulp'), nodemon=require('gulp-nodemon'), browser=require('browser-sync'); let relo ...

  4. Codeforces Round #129 (Div. 2) A

    Description The Little Elephant loves Ukraine very much. Most of all he loves town Rozdol (ukr. &quo ...

  5. 带图片的word快速插入到博客中

    最近在博客中写文章的时候,最烦的就是将word文档整体传到博客中,不能一次把图片粘贴上去,再次去添加图片的时候要截图还要找对位置才可上传,偶尔的机会在网上看到有人这么处理,挺好用的,这里我也做个备注. ...

  6. 转 怎样用grep命令去掉空格行和以#开头的行

    怎样用grep命令去掉空格行和以#开头的行 https://jingyan.baidu.com/article/359911f544c36b57fe030637.html

  7. Linux安装配置相关

    1.常用汇总 useradd usertemp //添加用户 passwd usertemp //修改/设置密码 userdel usertemp //删除用户 2. profile/baserc等配 ...

  8. InteliJ idea import project 找不到文件结构解决办法

    一.按下列步骤操作:       1. 关闭IDEA,        2.然后删除项目文件夹下的.idea文件夹       3.重新用IDEA工具打开项目: 二.import新项目之后,可能需要等1 ...

  9. Redis Windows环境搭建

    简介 Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理.它支持字符串.哈希表.列表.集合.有序集合,位图,hyperloglogs等数据类型.内置复制 ...

  10. CPU保护模式DPL、CPL简易理解

    现代INTEL CPU都有保护模式,实模式这两种CPU运行模式.当CPU加电,CPU初始化时就运行在是模式下,然后现代操作系统会从实模式跳转到保护模式! 为什么需要保护模式? 在最开始编程的汇编时代, ...