React后台管理系统-品类选择器二级联动组件
1.页面大致是这个样子

2.页面结构
- <div className="col-md-10">
- <select name="" onChange={(e) => this.onFirstCategoryChange(e)} className="form-control cate-select">
- <option value="">请选择一级分类</option>
- {
- //箭头函数=>右边,加上了{}就需要return,不加就不需要return
- this.state.firstCategoryList.map(
- (category, index) => <option value={category.id} key={index}>{category.name}</option>)
- }
- </select>
- { this.state.secondCategoryList.length ?
- <select name="" onChange={(e) => this.onSecondCategoryChange(e)} className="form-control cate-select">
- <option value="">请选择二级分类</option>
- {
- this.state.secondCategoryList.map(
- (category, index)=> <option value={category.id} key={index}>{category.name}</option>
- )
- }
- </select> : null
- }
- </div>
3.定义state里边的数据
- this.state = {
- firstCategoryList : [],
- firstCategoryId : 0,
- secondCategoryList : [],
- secondCategoryId : 0,
- }
监听select选择框,当一级品类和二级品类改变的时候, 更新state里边firstCategoryId和secondCategoryId的值
- //一级品类改变事件
- onFirstCategoryChange(e){
- //取一级品类的值,没有的话为0
- let newValue=e.target.value || 0;
- this.setState({
- firstCategoryId : newValue,
- //当一级品类改变时清空二级品类
- secondCategoryList : [],
- secondCategoryId : 0,
- },() => {
- //加载二级分类
- this.loadSecondCategory()
- })
- }
- //二级品类改变事件
- onSecondCategoryChange(e){
- //取一级品类的值,没有的话为0
- let newValue=e.target.value || 0;
- this.setState({
- secondCategoryId : newValue,
- },() => {
- //加载二级分类
- this.onPropsCategoryChange();
- })
- }
加载一级分类
- //加载一级分类
- loadFirstCategory(){
- _product.getCategoryList().then(res => {
- this.setState({
- firstCategoryList : res
- });
- }, errMsg => {
- _mm.errorTips(errMsg);
- });
- }
加载二级分类
- //加载二级分类
- // 加载二级分类
- loadSecondCategory(){
- _product.getCategoryList(this.state.firstCategoryId).then(res => {
- this.setState({
- secondCategoryList : res
- });
- }, errMsg => {
- _mm.errorTips(errMsg);
- });
- }
4.把最新的firstCategoryId和secondCategoryId的值传入父组件,更新父组件里边一级品类和二级品类
- // 传给父组件选中的结果
- onPropsCategoryChange(){
- // 判断props里的回调函数存在
- let categoryChangable = typeof this.props.onCategoryChange === 'function';
- // 如果是有二级品类
- if(this.state.secondCategoryId){
- categoryChangable && this.props.onCategoryChange(this.state.secondCategoryId, this.state.firstCategoryId);
- }
- // 如果只有一级品类
- else{
- categoryChangable && this.props.onCategoryChange(this.state.firstCategoryId, 0);
- }
- }
父组件使用CategorySelector组件
- <div className="form-group">
- <label className="col-md-2 control-label">所属分类</label>
- <CategorySelector
- categoryId={this.state.categoryId}
- parentCategoryId={this.state.parentCategoryId}
- onCategoryChange={ (categoryId,parentCategoryId) => this.onCategoryChange(categoryId,parentCategoryId)} />
更新父组件state里边一级品类和二级品类的值
- //品类改变事件
- onCategoryChange(categoryId,parentCategoryId){
- this.setState({
- categoryId : categoryId,
- parentCategoryId : parentCategoryId
- });
- }
React后台管理系统-品类选择器二级联动组件的更多相关文章
- React后台管理系统-品类的增加、修改和查看
1.页面 2.品类列表展示 let listBody = this.state.list.map((category, index) => { return ( ...
- React后台管理系统-添加商品组件
引入了CategorySelector 二级联动组件.FileUploader图片上传组件和RichEditor富文本编辑组件 import React from 'react'; import MU ...
- 《React后台管理系统实战 :一》:目录结构、引入antd、引入路由、写login页面、使用antd的form登录组件、form前台验证、高阶函数/组件
实战 上接,笔记:https://blog.csdn.net/u010132177/article/details/104150177 https://gitee.com/pasaulis/react ...
- react后台管理系统路由方案及react-router原理解析
最近做了一个后台管理系统主体框架是基于React进行开发的,因此系统的路由管理,选用了react-router(4.3.1)插件进行路由页面的管理配置. 实现原理剖析 1.hash的方式 ...
- 【共享单车】—— React后台管理系统开发手记:主页面架构设计
前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...
- Vue + Element-ui实现后台管理系统(4)---封装一个ECharts组件的一点思路
封装一个ECharts组件的一点思路 有关后台管理系统之前写过三遍博客,看这篇之前最好先看下这三篇博客.另外这里只展示关键部分代码,项目代码放在github上: mall-manage-system ...
- 《React后台管理系统实战 :二》antd左导航:cmd批量创建子/目录、用antd进行页面布局、分离左导航为单独组件、子路由、动态写左导航、css样式相对陷阱
一.admin页面布局及路由创建 0)cmd批量创建目录及子目录 //创建各个目录,及charts和子目录bar md home category product role user charts\b ...
- 《React后台管理系统实战 :三》header组件:页面排版、天气请求接口及页面调用、时间格式化及使用定时器、退出函数
一.布局及排版 1.布局src/pages/admin/header/index.jsx import React,{Component} from 'react' import './header. ...
- 【共享单车】—— React后台管理系统开发手记:UI菜单各个组件使用(Andt UI组件)
前言:以下内容基于React全家桶+AntD实战课程的学习实践过程记录.最终成果github地址:https://github.com/66Web/react-antd-manager,欢迎star. ...
随机推荐
- Murano Weekly Meeting 2016.07.12
Meeting time: 2016.July.12 1:00~2:00 Chairperson: Kirill Zaitsev, from Mirantis Meeting summary: 1. ...
- AndroidStudio3.0的安装和配置笔记
开发Android项目要搭建开发环境.可以选择使用Eclipse安装ADT插件来开发安卓项目,也可以使用谷歌的官方IDE——AndroidStudio3.0. AndroidStudio3.0安装的具 ...
- Facebook TSDB论文Gorilla分析
Facebook TSDB论文Gorilla分析 背景 TSDB时序数据库用于存储时间相关的数据,常用于监控系统的数据存储,分布式的TSDB提供了海量的数据存储能力,如InfluxDB.OpenTSD ...
- 介绍几个关于C/C++程序调试的函数
最近调试程序学到的几个挺有用的函数,分享一下,希望对用C/C++的朋友有所帮助! 1. 调用栈系列下面是函数原型: 1 2 3 4 #include "execinfo .h" i ...
- JQuery 技巧总结
一.简介 1.1.概述 随着WEB2.0及ajax思想在互联网上的快速发展传播,陆续出现了一些优秀的Js框架,其中比较著名的有Prototype.YUI.jQuery.mootools.Bindows ...
- C#语言开发规范
1. 命名规范 a) 类 [规则1-1]使用Pascal规则命名类名,即首字母要大写. eg: Class Test { ... } [规则1-2]使用能够反映类功能的名词或名词短语命名类. [规则 ...
- c#-day02学习笔记
类型转化 为什么要类型转化:因为C#语言是强类型的语言,所以区分了很多的类型,类型和类型之间是不能直接赋值的,如果要赋值 就需要转换类型 类型转换分为两大类: 第一类:隐式转换 隐式转换是系统默认的转 ...
- IIS_常见问题及解决方法
配置错误 在唯一密钥属性“value”设置为“default.aspx”时,无法添加类型为“add”的重复集合项 配置文件 \\*******\web\web.config web.config中 & ...
- C#委托(一)——说明及举例
C#命名空间下有五种类型,分别为: 类.构造.接口.枚举.委托. 委托被定义为5中基本类型的一种,也就意味着代码可以这么写: using System; namespace Test { delega ...
- MySQL如何查询当月数据
自己写了一个比较简单效率又高的方法,分享给大家: WHERE addTime BETWEEN DATE_FORMAT(NOW(),'%Y-%m-01') AND NOW() 方法就是过滤 本月1日到当 ...