1.商品列表页面结构

  1. <div id="page-wrapper">
  2.              <PageTitle title="商品列表">
  3.                  <div className="page-header-right">
  4.                      <Link to="/product/save" className="btn btn-primary">
  5.                          <i className="fa fa-plus"></i>
  6.                          <span>添加商品</span>
  7.                      </Link>
  8.                  </div>
  9.              </PageTitle>
  10.              <ListSearch onSearch={(searchType, searchKeyword) => {this.onSearch(searchType, searchKeyword)}} />
  11.              <TableList tableHeads={tableHeads}>
  12.                  {
  13.                      this.state.list.map((product, index) => {
  14.                          return (
  15.                              <tr key={index}>
  16.                                  <td>{product.id}</td>
  17.                                  <td>
  18.                                      <p>{product.name}</p>
  19.                                      <p>{product.subtitle}</p>
  20.                                  </td>
  21.                                  <td>¥{product.price}</td>
  22.                                  <td>
  23.                                      <span>{product.status == 1 ? '在售' : '已下架'}</span>
  24.                                      <button className="btn btn-xs btn-warning"
  25.                                          onClick={(e) => {this.onSetProductStatus(e, product.id, product.status)}}>{product.status == 1 ? '下架' : '上架'}</button>
  26.                                  </td>
  27.                                  <td>
  28.                                      <Link className="opear" to={`/product/detail/${product.id}`}>详情</Link>
  29.                                      <Link className="opear" to={`/product/save/${product.id}`}>编辑</Link>
  30.                                  </td>
  31.                              </tr>
  32.                          );
  33.                      })
  34.                  }
  35.              </TableList>
  36.              <Pagination current={this.state.pageNum}
  37.                  total={this.state.total}
  38.                  onChange={(pageNum) => this.onPageNumChange(pageNum)}/>
  39.          </div>

2.请求后台数据

  1. this.state = {
  2.            list : [],
  3.            pageNum : 1,
  4.            listType : 'list'
  5.        };
  6. componentDidMount(){
  7.      this.loadProductList();
  8.    }
  9.    // 加载商品列表
  10.    loadProductList(){
  11.        let listParam = {};
  12.        listParam.listType = this.state.listType;
  13.        listParam.pageNum = this.state.pageNum;
  14.        //如果是搜索的话需要传入搜索类型和搜索关键字
  15.        if(this.state.listType === 'search'){
  16.            listParam.searchType=this.state.searchType;
  17.            listParam.keyword = this.state.searchKeyword;
  18.        }
  19.        _product.getProductList(listParam).then( res => {
  20.            this.setState(res);
  21.        }, errMsg => {
  22.            this.setState({
  23.                list : []
  24.            })
  25.            _mm.errorTips(errMsg);
  26.        })
  27.    }

3.当页码切换时,更新state里边pageNum的值

  1. //更新页码
  2.    onPageNumChange(pageNum){
  3.       //获取当前页,然后更改this.state里边的pageNum,成功以后调用this.loadProductList()方法
  4.       this.setState({
  5.          pageNum:pageNum
  6.       }, () => {
  7.           this.loadProductList();
  8.       });
  9.    }

4.改变商品的上下架状态

  1. //改变商品的上下架状态
  2.     //1是上架,2是下架
  3.     onSetProductStatus(e,productId,currentStatus){
  4.         let newStatus = currentStatus == 1 ? 2 : 1;
  5.         // 1是上架 ,2 是下架 确认应该是说相反的
  6.         let confirmTips=currentStatus == 1 ? "确认下架该商品吗" : "确认上架该商品吗"
  7.         if(window.confirm(confirmTips)){
  8.             _product.setProductStatus(
  9.                 {
  10.                     productId:productId,
  11.                     status:newStatus
  12.                 }
  13.             ).then(res => {
  14.                 _mm.successTips(res);
  15.                 this.loadProductList();
  16.             }, errorMsg => {
  17.                 _mm.errorTips(res);
  18.  
  19.             });
  20.         }
  21.     }

React后台管理系统-商品管理列表组件的更多相关文章

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

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

  2. React后台管理系统-订单管理

    1.订单管理页面和商品管理页面类似,都是一个搜索组件+列表组件 2.搜索框search组件 import React from 'react';   class ListSearch extends ...

  3. React后端管理系统-商品详情detail组件

    import React from 'react'; import MUtil from 'util/mm.jsx' import Product from 'service/product-serv ...

  4. 「超市管理系统——商品管理」 · Java Swing + MySQL JDBC开发

    项目下载:https://download.csdn.net/download/weixin_44893902/13715024 1.9元付费赞助下载:https://download.csdn.ne ...

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

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

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

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

  7. 《React后台管理系统实战 零》:基础笔记

    day01 1. 项目开发准备 1). 描述项目 2). 技术选型 3). API接口/接口文档/测试接口 2. 启动项目开发 1). 使用react脚手架创建项目 2). 开发环境运行: npm s ...

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

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

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

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

随机推荐

  1. 洛谷P2574 XOR的艺术

    题目描述 \(AKN\)觉得第一题太水了,不屑于写第一题,所以他又玩起了新的游戏.在游戏中,他发现,这个游戏的伤害计算有一个规律,规律如下 1. 拥有一个伤害串为长度为\(n\)的\(01\)串. 2 ...

  2. Maven项目聚合 jar包锁定 依赖传递 私服

    <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...

  3. linux别名防删除

    最近有不相信rm -rf 了,虽然恢复了但是很难受啊 加个别名吧, 1.查看系统别名配置 alias 2.配置别名(临时生效) alias rm='echo do not use rm command ...

  4. beeline连接hive

    beeline -u jdbc:hive2://192.168.1.77:10000 zeppelin default jdbc: jdbc:hive2://nn01.ooccpp.com:2181/ ...

  5. jquery——元素节点操作

    插入节点: 1.append()和appendTo():在现存元素的内部,从后面插入元素 <script type="text/javascript"> $(funct ...

  6. windows下显示隐藏的文件

    文件--文件夹选项---查看---高级设置----隐藏文件和文件夹----显示隐藏的文件.文件夹和驱动器

  7. UnityError 动画系统中anystate跳转重复播放当前动画解决方案

  8. Java集合——集合框架Iterator接口

    1.集合输出 很多情况下我们需要把集合的内容进行输出,也就是遍历集合. 遍历集合的方式有以下几种: 1.Iterator 2.ListIterator 3.Enumeration(枚举方式,比较老一般 ...

  9. varnish与squid的比较

    生产环境中尝试使用varnish替代squid的主要原因: 1. squid不支持多核cpu, 生产环境中大多使用Dell R610系列,这种类型机器配置为2个4核双线程cpu, 操作系统识别为16个 ...

  10. 用CSS控制图片大小显示的方法

    图片自动适应大小是一个非常常用的功能,在进行制作的时候为了防止图片撑开容器而对图片的尺寸进行必要的控制,我们可不可以用CSS控制图片使它自适应大小呢? 可以通过按比例缩小或者放大到某尺寸(自己指定), ...