react实现动态选择框

本文实例为大家分享了react实现动态选择框的具体代码,供大家参考,具体内容如下

小需求

在工作中,我们也会碰到这种需求: 为了提高用户的体验,在搜索的时候,采用灵活查询。用户可以自己选择查询项并且填写对应的值。

这篇博文涉及知识点在这篇博文“react+antd 动态编辑表格数据”中提及过。大家可以先去这篇学习一下然后这里。

示例代码

import React, { Component, useState } from 'react';
import { Button, Col, message, Select, Row, Input } from 'antd'
import { PlusCircleOutlined, MinusCircleOutlined } from '@ant-design/icons';
const { Option } = Select
function Index() {

    // 可选项
    const [choseList, setChoseList] = useState(['商品ID', '款号', '产品线','一级类目','二级类目','三级类目','渠道'])

    // 已存在选
    const [exitChoseList, setExitChostList] = useState([])

    /**
     *  searchData的数据结构是:
     *      {
     *          // 选择项
                'sort': '',
                // 用户选择的值,即在多选框中选择的值
                'value': [],
                // 可选择项
                'chose_list': [],
                // 用户选择一个选择项之后,这个选择项对应的所有的选择。例如: 选择项为“季节”则春夏秋冬
                'value_chose_list':[]
            }
     */

    const [searchData, setSearchData] = useState([])

    return (
        <div>
            <Row style={{ marginLeft: 50, marginTop: 50, width:'100vw', }}>
                {
                    searchData.map((item, index) => {
                        return <Col span={8} style={{ display: 'flex', marginTop:5 }}>
                            <Select style={{ width: 150 }} value={searchData[index]['sort']} onChange={(value) => {
                                // 判断用户选择的选择项是否已经存在
                                if(exitChoseList.indexOf(value) == -1){
                                    // 用户选择的选择项不存在的时候,判断是否已经有选择项了
                                    if(searchData[index]['sort']!= ''){
                                        // 要是存在选择项的话
                                        let obj = [...exitChoseList]
                                        // 先把之前的选择项删除掉
                                        obj.splice(index, 1)
                                        // 添加新的选择项
                                        obj.push(value)
                                        setExitChostList(obj)
                                        let searchDataObj = [...searchData]
                                        setSearchData([])
                                        // 然后将其他的值都配置初始化
                                        searchDataObj[index]['value'] = []
                                        searchDataObj[index]['sort'] = value
                                        searchDataObj[index]['value_chose_list'] = [1,2,3]
                                        setSearchData(searchDataObj)
                                    }else{
                                        // 不存在选择项的话
                                        let obj = [...exitChoseList]
                                        setExitChostList([])
                                        // 添加选择项
                                        obj.push(value)
                                        setExitChostList(obj)
                                        let searchDataObj = [...searchData]
                                        setSearchData([])
                                        searchDataObj[index]['sort'] = value
                                        searchDataObj[index]['value_chose_list'] = [1,2,3]
                                        setSearchData(searchDataObj)
                                    }
                                }else{
                                    message.warn('已存在这个选择项了')
                                }
                               
                            }}>
                                {
                                    item.chose_list.map(i => {
                                        return <Option value={i}>{i}</Option>
                                    })
                                }
                            </Select>
                            {
                                searchData[index]['sort'] == '商品ID' || '款号' ? <Input style={{ width: 200 }} value={searchData[index]['value']} onChange={(e) => {
                                    let obj = [...searchData]
                                    obj[index]['value'] = e.target.value
                                    setSearchData(obj)
                                }} />
                                    : <Select value={searchData[index]['value']} style={{ width: 200 }} mode="multiple" onChange={(value) => {
                                        let obj = [...searchData]
                                        obj[index]['value'] = value
                                        setSearchData(obj)
                                    }}>
                                        {
                                            item.value_chose_list.map(i => {
                                                return <Option value={i}>{i}</Option>
                                            })
                                        }
                                    </Select>
                            }
                            <MinusCircleOutlined style={{marginTop:5, marginLeft:10, marginRight:10}} onClick={()=>{
                                if(searchData[index]['sort'] != ''){
                                    let value = searchData[index]['sort']
                                    let exitChoseObj = [...exitChoseList]
                                    setExitChostList([])
                                    exitChoseObj.pop(value)
                                    setExitChostList(exitChoseObj)
                                    let obj = [...searchData]
                                    obj.splice(index, 1);
                                    setSearchData(obj)
                                }
                            }} />
                        </Col>
                    })
                }
                <PlusCircleOutlined style={{ marginLeft: 20, marginTop:10 }} onClick={() => {
                    let obj = [...searchData]
                    setSearchData([])
                    let arr3 = choseList.filter(items => exitChoseList.indexOf(items) == -1);
                    obj.push({
                        'sort': '',
                        'value': [],
                        'chose_list': arr3,
                        'value_chose_list':[]
                    })
                    setSearchData(obj);
                }} />

            </Row>
            <div style={{marginTop:20, marginLeft:50, display:'flex'}}>
                <Button type="primary" onClick={()=>{
                    console.log(searchData)
                }}>搜索</Button>
                <Button type="primary" danger onClick={()=>{
                    setSearchData([])
                    setExitChostList([])
                }}>重置</Button>
            </div>
        </div>

    )

}

export default Index

总结

这里就是采用了react中的: […searchData] 这个特性,造的第一个组件。后续还会继续分享自己的造的组件。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • react-native 封装选择弹出框示例(试用ios&android)

    在开发 App 的时候,经常会使用到对话框(又叫消息框.提示框.告警框). 在web开发中经常会用得到.今天就来介绍了一下react-native 封装弹出框 之前看到react-native-image-picker中自带了一个选择器,可以选择拍照还是图库,但我们的项目中有多处用到这个选择弹出框,所以就自己写了一下,最最重要的是ios和Android通用.先上动态效果图~ 一.封装要点 1.使用动画实现弹框布局及显示隐藏效果 2.通过一个boolean值控制组件的显示隐藏 3.弹框选项数组通过

  • react-native DatePicker日期选择组件的实现代码

    本教程的实现效果如下: 为了实现其淡入/淡出的覆盖效果, 还有取消按钮, 在此用了一个三方的组件, 大家可以先安装一下: 三方组件的地址:https://github.com/eyaleizenberg/react-native-custom-action-sheet(可以看看,也可以直接按我的步骤走) 1. 在terminal的该工程目录下运行: npm install react-native-custom-action-sheet --save 2. 然后运行: npm start 3.

  • React Native日期时间选择组件的示例代码

    React Native日期时间选择组件:react-native-datepicker,支持安卓和IOS双平台,支持单独选择日期.单独选择时间和选择日期和时间,支持自定义日期格式. 效果图 安装方法 npm install react-native-datepicker --save 示例代码 <Text style={styles.instructions}>time: {this.state.time}</Text> <DatePicker style={{width:

  • react实现动态选择框

    本文实例为大家分享了react实现动态选择框的具体代码,供大家参考,具体内容如下 小需求 在工作中,我们也会碰到这种需求: 为了提高用户的体验,在搜索的时候,采用灵活查询.用户可以自己选择查询项并且填写对应的值. 这篇博文涉及知识点在这篇博文“react+antd 动态编辑表格数据”中提及过.大家可以先去这篇学习一下然后这里. 示例代码 import React, { Component, useState } from 'react'; import { Button, Col, messag

  • 多级联动下拉选择框,动态获取下一级

    多级联动下拉选择框,动态获取下一级,每一级数据为XML,可支持无限级(浏览器端需要Microsoft.XMLDOM支持) 项目需要,一个材料类别表,三级,总共有7000多条记录,如果一次获取会很慢的,所以就是用了动态读取,每次就读一级,且服务器端使用了缓存,效率还不错. HTML代码如下: <select name="MaterialClass1" ChildSelectName="MaterialClass2"></select><s

  • Vue表单绑定的实例代码(单选按钮,选择框(单选时,多选时,用 v-for 渲染的动态选项)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Vue表单绑定(单选按钮,选择框(单选时,多选时)</title> </head> <body> <!-- 单选按钮 --> <div id="app"> <input type="radio" valu

  • Layui动态生成select下拉选择框不显示的解决方法

    给代码添加如下部分: layui.use('form', function(){ //此段代码必不可少 var form = layui.form; form.render(); }); 实现效果: HTML代码: <div class="layui-form-item"> <label class="layui-form-label">执行周期</label> <div class="layui-input-in

  • js实现上传文件添加和删除文件选择框

    本文这里给大家说个用javascript实现的很实用的功能,是在上传附件的时候,可以动态地添加和删除文件选择框,然后一次性上传. 从理论上看,实现起来比较容易,但实际工作的时候还是遇到两个难点,这些难点归结起来都是一个原因造成的,那就是浏览器的兼容性.在脚本中要用到两个函数:insertAdjacentHTML和removeChild,而恰好这两个函数在Firefox下都不能正常使用.几乎花费了一天的时候,在网上搜索着解决的方法,还好被找到了,也让我大松一口气. 具体两个函数是这样的: <scr

  • 基于jQuery下拉选择框插件支持单选多选功能代码

    由于最近项目的需求,需要做一个下拉选择框的插件,支持单选显示表单数据,多选显示表格数据,该插件主要运用了jQuery与jqgrid以及easyui. 下面给大家展示下效果图,如果大家感觉还不错,请参考实现代码: 多选:呈现列表 具体代码如下所示: /** *下拉框插件-chooseList *调用插件的方式以及格式: * 1.首先你需要创建一个div面板,给div定义ID * 2.在你所需要的地方调用插件: * 参数说明: * $("#divID").chooseList({ * qu

  • jquery通过select列表选择框对表格数据进行过滤示例

    jquery通过select列表选择框对表格数据进行过滤 表格数据 复制代码 代码如下: <table id="example">    <thead>        <tr>            <th>Name</th>            <th>Surname</th>        </tr>    </thead>    <tbody>       

  • Android Spinner列表选择框的应用

    Android  Spinner列表选择框的应用 Spinner 是 Android 的列表选择框,不过 spinner 并不需要显示下拉列表,而是相当于弹出一个菜单供用户选择. Spinner 属性: ● android:spinnerMode:列表显示的模式,有两个选择,为弹出列表(dialog)以及下拉列表(dropdown),如果不特别设置,为下拉列表. ● android:entries:使用<string-array.../>资源配置数据源. ● android:prompt:对当

  • Android 列表选择框 Spinner详解及实例

    Android 列表选择框 Spinner详解及实例 Spinner 是 Android 的列表选择框,不过 spinner 并不需要显示下拉列表,而是相当于弹出一个菜单供用户选择. Spinner 属性: ● android:spinnerMode:列表显示的模式,有两个选择,为弹出列表(dialog)以及下拉列表(dropdown),如果不特别设置,为下拉列表. ● android:entries:使用<string-array.../>资源配置数据源. ● android:prompt:

  • 原生JS实现自定义下拉单选选择框功能

    浏览器自带的原生下拉框不太美观,而且各个浏览器表现也不一致,UI一般给的下拉框也是和原生的下拉框差别比较大的,这就需要自己写一个基本功能的下拉菜单/下拉选择框了.最近,把项目中用到的下拉框组件重新封装了一下,以构造函数的方式进行封装,主要方法和事件定义在原型上,下面是主要的实现代码并添加了比较详细的注释,分享出来供大家参考.代码用了ES6部分写法如需兼容低版本浏览器请把相关代码转成es5写法,或者直接bable转下. 先放个预览图吧,后面有最终的动态效果图:(样式和交互参考了阿里和Iview U

随机推荐