Как использовать Tab вместо Enter в Downshift для выбора текущего пункта меню?
Это касается:
https://github.com/paypal/downshift
Я установил onKeyDown
обработчик распознает нажатие клавиши Tab, и я могу получить highlightedIndex
значение правильно, но как использовать это, чтобы изменить inputValue
?
import React from 'react'
import Downshift from 'downshift'
import {
Label,
Menu,
ControllerButton,
Input,
Item,
ArrowIcon,
XIcon,
css,
itemToString,
getItems,
} from '../shared'
class App extends React.Component {
render() {
return (
<div
{...css({
display: 'flex',
flexDirection: 'column',
marginTop: 50,
})}
>
<Downshift
onChange={selection =>
alert(
selection
? `You selected ${itemToString(selection)}`
: 'selection cleared',
)
}
itemToString={itemToString}
>
{({
getLabelProps,
getInputProps,
getToggleButtonProps,
getMenuProps,
getItemProps,
isOpen,
clearSelection,
selectedItem,
inputValue,
highlightedIndex,
}) => (
<div {...css({width: 250, margin: 'auto'})}>
<Label {...getLabelProps()}>Find a Star Wars character</Label>
<div {...css({position: 'relative'})}>
<Input
{...getInputProps({
isOpen,
placeholder: 'Enter a name',
**onKeyDown: event => {
console.log(event.key)
if (event.key === 'Tab') {
console.log(highlightedIndex)
}
},**
})}
/>
{selectedItem ? (
<ControllerButton
onClick={clearSelection}
aria-label="clear selection"
>
<XIcon />
</ControllerButton>
) : (
<ControllerButton {...getToggleButtonProps()}>
<ArrowIcon isOpen={isOpen} />
</ControllerButton>
)}
</div>
<div {...css({position: 'relative'})}>
<Menu {...getMenuProps({isOpen})}>
{isOpen
? getItems(inputValue).map((item, index) => (
<Item
key={item.id}
{...getItemProps({
item,
index,
isActive: highlightedIndex === index,
isSelected: selectedItem === item,
})}
>
{itemToString(item)}
</Item>
))
: null}
</Menu>
</div>
</div>
)}
</Downshift>
</div>
)
}
}
export default App
0 ответов
Я обнаружил, что в этой ситуации помогает stateReducer.
stateReducer={(_, changes) => {
if (changes.type === Downshift.stateChangeTypes.blurInput) {
return {
...changes,
inputValue: your value,
isOpen: false
}
}
return changes
}}
в паре с входами getInputProps.onKeyDown
событие
<Input {...getInputProps({
onKeyDown: event => {
switch (event.key) {
case 'Tab': {
// use the highlighted or first value
// update the state
break;
}
default:
break;
}
}
})} />