当前位置: 首页 > article >正文

react通过下拉框选择多个,并展示在下方的方式

以备后用,直接上代码:

一、方法:

//查询学校一级部门列表
    async orgFirstLevelList() {
        let data = {
            schoolId:this.state.schoolId
        };
        let depList = await orgFirstLevelList(data);
        this.setState({
            depList: depList
        })
    }
    //删除所选部门
    deleteDep(index) {
        let {selectDepList} = this.state;
        selectDepList.splice(index,1);
        this.setState({ selectDepList });
    }
    //添加所选部门
    addDep(e) {
        let orgName = null;
        let { depList,selectDepList} = this.state;
        //判断已添加列表中是否已存在
        for(let i = 0;i < selectDepList.length; ++i){
            if(selectDepList[i].id === e[0]) {
                this.mesWarning('该部门已添加过了,无需重复添加')
                return;
            }
        }
        for(let i = 0;i < depList.length; ++i){
            if(depList[i].id === e[0]) {
                orgName = depList[i].orgName;
                break;
            }
        }
        selectDepList.push({id:e[0], orgName:orgName});
        this.setState({ selectDepList: selectDepList});
        this.props.form.setFieldsValue({orgId:""})
    }

二、form及选择展示

<Form.Item label="所属部门">
{
     getFieldDecorator('depId', {
         rules: [
             {
              required: true,
              message: '请输入所属组织',
             },]
     })(
         <Cascader
         fieldNames={{label: 'orgName', value: 'id'}}
         options={depList}
         placeholder="请选择所属组织,支持多选"
         changeOnSelect
         onChange={(e) => this.addDep(e)}
         disabled={this.state.isLook}
         getPopupContainer={triggerNode => triggerNode.parentNode || document.body}
         />)}
</Form.Item>
  {selectDepList.length > 0?
    <Col span={24}>
    <div className="diyTag">
    {
      selectDepList.map((item,index)=>{
        return(
         <Tag key={index} id={item.id}>
         {item.orgName}
         <span onClick={() => this.deleteDep(index)}>
            {closeBtn}
         </span>
       </Tag>)
      })
    }
    </div>
    </Col>:""
}


http://www.kler.cn/news/321721.html

相关文章:

  • 看Threejs好玩示例,学习创新与技术(React-three-fiber)
  • 【C++篇】从零实现 C++ Vector:深度剖析 STL 的核心机制与优化
  • SpringCloud源码:客户端分析(二)- 客户端源码分析
  • ArduSub程序学习(11)--EKF实现逻辑①
  • [AI问答] Auto-sklearn和Auto-Keras对比
  • Ubuntu20.04.6 环境下docker设置proxy
  • SpringBoot-Starter2.7.3自动装配Redisson升级版本运行时的问题
  • 自动驾驶技术:人工智能驾驶的未来
  • tauri程序加载本地图片或者文件在前端页面展示
  • ModStartCMS v8.9.0 图片上传优化,富文本编辑器修复
  • Spring Boot 实战:使用观察者模式实现实时库存管理
  • localectl 命令:系统语言、键盘布局和区域设置
  • CORE 中间件、wwwroot
  • C++11中引入的thread
  • 正向科技|格雷母线定位系统的设备接线安装示范
  • 脚手架是什么?详细版+通俗易懂版!!!!!!
  • DNS与host文件
  • 职业技能大赛-自动化测试笔记(PageObject)分享-4
  • 如何将自定义支付网关与 WooCommerce Checkout 区块集成
  • HarmonyOS---权限和http/Axios网络请求
  • 处理 VA02修改行项目计划行(SCHEDULE LINES )报错:不可能确定一个消耗帐户
  • count(1)、count(*) 与 count(列名) 的区别
  • zabbix“专家坐诊”第257期问答
  • 19、网络安全合规复盘
  • C++ | Leetcode C++题解之第440题字典序的第K小数字
  • 【HDP】zookeeper未授权漏洞修复
  • C语言课程设计题目四:实验设备管理系统设计
  • Flutter鸿蒙化环境配置(windows)
  • 网站设计中安全方面都需要有哪些考虑
  • 【opencv】——为arm平台交叉编译