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>:""
}
相关推荐
摘星编程18 分钟前
React Native + OpenHarmony:Timeline垂直时间轴
javascript·react native·react.js
2501_944525541 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 支出分析页面
android·开发语言·前端·javascript·flutter
jin1233222 小时前
React Native鸿蒙跨平台完成剧本杀组队详情页面,可以复用桌游、团建、赛事等各类组队详情页开发
javascript·react native·react.js·ecmascript·harmonyos
李白你好2 小时前
Burp Suite插件用于自动检测Web应用程序中的未授权访问漏洞
前端
经年未远3 小时前
vue3中实现耳机和扬声器切换方案
javascript·学习·vue
刘一说3 小时前
Vue 组件不必要的重新渲染问题解析:为什么子组件总在“无故”刷新?
前端·javascript·vue.js
jin1233223 小时前
基于React Native鸿蒙跨平台移动端表单类 CRUD 应用,涵盖地址列表展示、新增/编辑/删除/设为默认等核心操作
react native·react.js·ecmascript·harmonyos
可触的未来,发芽的智生3 小时前
狂想:为AGI代称造字ta,《第三类智慧存在,神的赐名》
javascript·人工智能·python·神经网络·程序人生
徐同保4 小时前
React useRef 完全指南:在异步回调中访问最新的 props/state引言
前端·javascript·react.js
fanruitian4 小时前
uniapp 创建项目
javascript·vue.js·uni-app