跟一般的管理系统差不多

一、需求

1.新增申请和修改的弹窗里面的部门跟应用组改成下拉框,并调取后台接口获取到相应的值。
1.1相应的代码
// 获取部门
getDepartment = () => {
promiseAjax.get('/org/departments/findDeptList?level=4').then(res => {
if (res.code === '0') {
let productDeptObj = this.state.productDeptObj;
res.data.forEach(item => {
productDeptObj[item.id] = item;
});
console.log(productDeptObj, 'q1111');
this.setState({productDept: res.data || [], productDeptObj});
} else {
message.error(res.message);
}
});
}
form表单里面
<Select onChange={this.handleChangeProductDept}>
{
productDept.map(item => {ß
return <Option key={item.id} value={item.id}>{item.deptName}</Option>;
})
}
</Select>
// 获取应用组
handleChangeProductDept = (id) => {
const {setFieldsValue} = this.props.form;
setFieldsValue({productGroupProduct: undefined});
promiseAjax.get(`/org/thirdparty/dept/group?id=${id}&level=5`).then(res => {
if (res.code === '0') {
let productGroupObj = this.state.productGroupObj;
res.data.forEach(item => {
productGroupObj[item.id] = item;
});
this.setState({productGroup: res.data, productGroupObj});
} else {
message.error(res.message);
}
});
}
form表单里面
<Select>
{
productGroup.map(item => {
return <Option key={item.id} value={item.id}>{item.name}</Option>;
})
}
</Select>

在state里面声明productDept:[],productGroup:[],请求成功this.setState({productGroup/productDept:res.data});
在表单中分别遍历两个数组

获取部门数据后台参数
data: [{id: "1231648600", deptName: "商户事业部"}, {id: "1746345310", deptName: "综合管理部"},…]
0: {id: "1231648600", deptName: "商户事业部"}
1: {id: "1746345310", deptName: "综合管理部"}
2: {id: "1879685755", deptName: "研发部"}
3: {id: "1889850226", deptName: "人事行政部"}
4: {id: "688950687", deptName: "财务部"}
此时item是data的每一组对象,也就是01234中的所有值,所以展示出来的部门名称是item.deptName,此时的value是item.id

获取应用组数据后台参数
data: [{id: "1388050926", name: "招聘组"}, {id: "1311206076", name: "发展组"}]
0: {id: "1388050926", name: "招聘组"}
1: {id: "1311206076", name: "发展组"}
此时的item同上,所以展示出来的应用组名称是item.name,此时的value 是item.id

二、遇到的问题以及解决办法
1.在向后台传递参数的时候,后台需要4个参数,分别是部门名称、部门id、应用组名称、应用组id,而此时表单中获取到的是部门id和应用组id,所以我们必须通过这个id去获取到对应的name,
但是通过后台传递的数据可以看出id和name是同级并列的,看似没有任何关系,那么如何获取
以部门为例:我们可以知道现在id和deptName是包在同一个对象里面的,那么首先我声明一个空的对象producDeptObj{},

然后在获取部门的方法里遍历
res.data.forEach(item => {
productDeptObj[item.id] = item; 将数组的整体赋给id,此时的id里面包含id和deptName,
接下来如果想获取到name 只需productDeptObj[item.id].name就可以了。
});

在点击提交的时候 const department = this.state.productDeptObj[fieldsValue.department1].deptName; // 获取到部门名称
const department = this.state.productDeptObj[values.department1] ? this.state.productDeptObj[fieldsValue.department1].deptName : '';
// 做一个判断,如果后台数据有问题 为了防止报错,先判断一下
this.state.productDeptObj[values.department1]是否可以取到,
如果可以再去取对应的name,如果取不到就返回一个空。
注意⚠️
this.state.productDeptObj[values.department1] 之所以可以用this.state可以取到 productDeptObj,
是因为在获取部门的方法里面 setState了productDeptObj
this.setState({productDept: res.data || [], productDeptObj});

以上是我在做项目的时候遇到的问题,可能很简单,但是当时也是把自己难住了,希望可以帮助遇到以上问题的小伙伴们,第一次写博客还有很多不足之处,希望多多包涵!

基于react的MQ管理系统遇到的问题以及解决办法的更多相关文章

  1. 基于ABP的应用执行Update-Database出现异常的解决办法

    今天在QQ群中看到有网友在更新数据库执行Update-Database时出现下面的错误: 为了能让搜索引擎搜索到,特意加上该错误的文字说明: 在与 SQL Server 建立连接时出现与网络相关的或特 ...

  2. react native 运行项目下载gradle慢的解决办法

    react-native run-android 慢 React-native run-Android中需要下载https://services.gradle.org/distributions/gr ...

  3. 基于 React.js + Redux + Bootstrap 的 Ruby China 示例 (转)

    一直学 REACT + METEOR 但路由部分有点问题,参考一下:基于 React.js + Redux + Bootstrap 的 Ruby China 示例 http://react-china ...

  4. easyconf——基于AugularJS的配置管理系统开发框架

    目录 1 easyconf的诞生2 easyconf的设计理念 2.1 总体设计 2.2 细节设计 2.2.1 CRUD操作 2.2.2 即时校验 2.2.3 下拉框设计3 easyconf使用指南 ...

  5. RSuite 一个基于 React.js 的 Web 组件库

    RSuite http://rsuite.github.io RSuite 是一个基于 React.js 开发的 Web 组件库,参考 Bootstrap 设计,提供其中常用组件,支持响应式布局. 我 ...

  6. 基于React Native的Material Design风格的组件库 MRN

    基于React Native的Material Design风格的组件库.(为了平台统一体验,目前只打算支持安卓) 官方网站 http://mrn.js.org/ Github https://git ...

  7. 基于ArcEngine的影像数据管理系统研制

    基于ArcEngine的影像数据管理系统研制 如果批处理,速度很慢,效率低. 详情如下: 分成很多小块的影像数据,要达到连续显示的效果,并导入ArcSDE for SQL Server中以方便管理.在 ...

  8. 【课程分享】基于plusgantt的项目管理系统实战开发(Spring3+JDBC+RMI的架构、自己定义工作流)

    基于plusgantt的项目管理系统实战开发(Spring3+JDBC+RMI的架构.自己定义工作流) 课程讲师:张弘 课程分类:Java 适合人群:中级 课时数量:37课时 用到技术:Spring  ...

  9. 基于react全家桶+antd-design+webpack2+node+express+mongodb开发的前后台博客系统

    很久没更新博客,最近也有点忙,然后业余时间搞了一个比较完整基于react全家桶+antd-design+webpack2+node+express+mongodb开发的前后台博客系统的流程系统,希望对 ...

随机推荐

  1. STM32的PA15、PB3、 PB4管脚作普通管脚的解决办法

      最近做了一个板子,使用的是SWD方式进行下载程序,仅仅使用到SWDIO(PA13) 和SWCLK(PA14)两个管脚.我将PA15(JTDI)和PB3(JTDO)管脚用于他用(用于点LED使用), ...

  2. linux如何查看所有的用户和组信息?

    cat /etc/passwd cat /etc/passwd查看所有的用户信息,详情如下图   [步骤二]cat /etc/passwd|grep 用户名 cat /etc/passwd|grep ...

  3. stress负载生成器使用简介

    一.Stress工具原始网页: https://people.seas.harvard.edu/~apw/stress/ 二.Docker镜像的构建过程(dockerfile): progrium/s ...

  4. Jenkins 配置邮件通知步骤

    Jenkins 配置邮件通知前言 可以在Jenkins 中配置邮件通知,比如在构建失败时发送邮件通知项目组来及时修复问题. Jenkins 邮件通知功能的插件主要包括: Mailer Plugin ( ...

  5. VMware虚拟机安装CentOS 6.9图文教程

    1.Win7安装VMware虚拟机比较简单,直接从官网下载VMware安装即可,这里不再叙述. 2.接着从CentOS官网直接下载CentOS 6.9的iso镜像文件. 3.打开VMware,点击创建 ...

  6. 从mysql向HBase+Phoenix迁移数据的心得总结

    * 转载请注明出处 - yosql473 - 格物致知,经世致用 mysql -> HBase + Phoenix 1.总体方案有哪些? 1)通过Sqoop直接从服务器(JDBC方式)抽取数据到 ...

  7. 记一次linux上的ftp搭建过程

    最近公司测试环境需要搭建ftp,正好自己稍微有点空且这方面确实不会,就自告奋勇说让我先试试,玩炸了你们再帮忙重装系统重新搭吧(手动滑稽),虽然最终是完成了,但是中间磕磕碰碰遇到一些小问题,到处查百度, ...

  8. selenium在scrapy中的使用、UA池、IP池的构建

    selenium在scrapy中的使用流程 重写爬虫文件的构造方法__init__,在该方法中使用selenium实例化一个浏览器对象(因为浏览器对象只需要被实例化一次). 重写爬虫文件的closed ...

  9. 瀑布流布局(等宽不等高jQuery)

    在百度上看见的好多都是引用Masonry插件   ,之后我自己尝试了一个没有使用插件的 <body> <div id="main"> <div cla ...

  10. 重置密码解决MySQL for Linux错误 ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

    出现报错: Warning: World-writable config file '/etc/my.cnf' is ignored // 该文件权限过高ERROR 1045 (28000): Acc ...