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>:""
}
相关推荐
我命由我123459 分钟前
7.使用 VSCode 过程中的英语积累 - Terminal 菜单(每一次重点积累 5 个单词)
前端·ide·笔记·vscode·学习·编辑器·学习方法
Vinkan@29 分钟前
前端规范工程-5:Git提交信息规范(commitlint + czg)
前端·git·代码规范·前端工程
小彭努力中43 分钟前
43. 创建纹理贴图
前端·3d·webgl·贴图
山楂树の1 小时前
Threejs中使用A*算法寻路导航
前端·javascript·算法
清灵xmf1 小时前
CSS 效果:实现动态展示双箭头
前端·css
女德班吊车尾1 小时前
枚举值实现下拉和tag展示的组件封装(vue2+js+elementUI)
前端·javascript·elementui·vue
Liuxu09031 小时前
Ajax开发技术
java·前端·ajax·okhttp·javaweb
多敲代码防脱发1 小时前
Java数据结构链表(LinkedList详解)
java·开发语言·前端·jvm·数据结构·笔记·链表
徐同保2 小时前
vue3+PPTXjs 在线ppt预览
前端·javascript·powerpoint
汪子熙2 小时前
什么是 Angular 的 @HostBinding 注解
前端·javascript·angular.js