gpt4 book ai didi

reactjs - React-Select - 带有自定义处理程序的可点击值

转载 作者:行者123 更新时间:2023-12-04 16:42:33 24 4
gpt4 key购买 nike

使用 react-select,我想了解如何获取单击选定值(多个)时的事件。

我正在使用具有多选功能的 react-select ( https://react-select.com/home )。
作为一种魅力,但我想让值可点击/可切换以更改颜色/状态(而不是添加/删除)。最后以灰色/颜色显示它们以指示标记状态并将底层状态用于后续代码。
有什么方法可以实现这一目标,如果有,如何实现?

最佳答案

您可以传入自定义 MultiValueLabelMultiValueContainer并添加一个 onClick处理程序。

import React from "react";
import ReactDOM from "react-dom";
import Select, { components } from 'react-select';


const options = [
{value: '1', label: 'Item 1', isToggled: true},
{value: '2', label: 'Item 2', isToggled: false},
{value: '3', label: 'Item 3', isToggled: false},
{value: '4', label: 'Item 4', isToggled: false},
{value: '5', label: 'Item 5', isToggled: false},
{value: '6', label: 'Item 6', isToggled: false},
]

const ReactSelectStyles = () => ({
multiValueLabel: (styles, {data: { isToggled }}) => ({
...styles,
backgroundColor: isToggled ? 'hotpink' : null,
color: isToggled ? 'white' : null
}),
});

const handleMultiValueClick = (e, props) => {
e.stopPropagation();
e.preventDefault();


console.log('A multi value has been clicked', props);

const option = options.find(option => option.value === props.data.value);

option.isToggled = !option.isToggled
}

const MultiValueLabel = props => {
return (
<div onClick={(e) => handleMultiValueClick(e, props)}>
<components.MultiValueLabel {...props} />
</div>
);
};

function App() {
return (
<Select
closeMenuOnSelect={false}
components={{ MultiValueLabel }}
defaultValue={[options[0], options[2], options[4]]}
isMulti
options={options}
styles={ReactSelectStyles()}
/>
);
}

const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);

Working Example

关于reactjs - React-Select - 带有自定义处理程序的可点击值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56736061/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com