[英]Get value of select menus when clicking reset button React
我有一组 select 菜单,当我使用重置按钮重置它们时,我需要找出所有这些菜单的值。
问题是这仅适用于选项的更改事件,并且我无法使其在第一次单击时对重置按钮起作用,因为它没有检测到更改。
此处的代码示例: https://stackblitz.com/edit/react-rmp8kf
import React from 'react';
import { useState } from 'react';
import uuid from 'react-uuid';
export default function Select() {
const [value, setValue] = useState({
select1: '',
select2: '',
});
const selectOptions = [
{
options: [
{
text: 'All',
value: '0',
},
{
text: 'Blue',
value: '1',
},
{
text: 'Yellow',
value: '2',
},
{
text: 'Green',
value: '3',
},
],
},
{
options: [
{
text: 'All',
value: '0',
},
{
text: 'Black',
value: '1',
},
{
text: 'White',
value: '2',
},
],
},
];
const handleOnChange = (e) => {
const valueSelected = e.target.value;
setValue({
...value,
[e.target.name]: valueSelected,
});
printAllSelectValues();
};
const resetAllSelections = (e) => {
e.preventDefault();
setValue({
select1: '',
select2: '',
});
printAllSelectValues();
};
const resetSelection = (e) => {
e.preventDefault();
setValue({
...value,
[e.target.dataset.selectName]: '',
});
printAllSelectValues();
};
const printAllSelectValues = () => {
const selectMenus = document.querySelectorAll('select');
selectMenus.forEach((select) =>
console.log(select.name + '=' + select.value)
);
};
return (
<form>
<div>
<label>
<select
name="select1"
value={value.select1}
onChange={handleOnChange}
>
{selectOptions[0].options.map((option) => (
<option value={option.value} key={uuid()}>
{option.text}
</option>
))}
</select>
</label>
<button data-select-name="select1" onClick={resetSelection}>
Reset
</button>
</div>
<div>
<label>
<select
name="select2"
value={value.select2}
onChange={handleOnChange}
>
{selectOptions[1].options.map((option) => (
<option value={option.value} key={uuid()}>
{option.text}
</option>
))}
</select>
</label>
<button data-select-name="select2" onClick={resetSelection}>
Reset
</button>
</div>
<button onClick={resetAllSelections}>Reset All</button>
</form>
);
}
您链接的 stackblitz 沙箱似乎完全符合您的需要。 在以下情况下,您将正确获得这两个值:
问题是什么? 您想获取更新的值吗?
更新
好的。 所以 react 的本质是每个 state 更新都是异步的,这意味着您需要等待 state 更新碰巧使用其更新的值。 现在,您不能使用 Promise 或 async/await 来执行此操作,因为 react 是故意以这种方式构建的,并为您提供了执行此操作的工具。 所以你需要为此使用 useEffect 钩子。
https://stackblitz.com/edit/react-bekzpz
注意:值得一提的是,您不需要从 HTML 元素中获取数据,但如果您想在 react 中操作 DOM 元素,您不应该使用文档,而是使用 useRef 挂钩
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.