本篇内容介绍了“react如何实现动态选择框”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
在工作中,我们也会碰到这种需求: 为了提高用户的体验,在搜索的时候,采用灵活查询。用户可以自己选择查询项并且填写对应的值。
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如何实现动态选择框”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。