UI 不会使用 React Hooks 和表单提交重新渲染状态更新

IT技术 reactjs react-hooks
2021-04-07 19:23:54

我正在尝试使用 React Hooks 和表单更新 UI。我有一个状态设置来监视表单上的值,当我单击提交时,我想将此值添加到一个数组(保持状态)并将其显示在 UI 上。我的问题是,当我提交值时,尽管它已添加到数组中(并且状态已更新),但 UI 仅在我更改输入中的值时更新。

我的组件如下:

const PushToArrayUpdateState = () => {

    const [array, setArray] = useState([]);
    const [formVal, setFormVal] = useState(``);

    const handleSubmit = event => {
        event.preventDefault();
        let updateArray = array;
        updateArray.push(formVal);
        console.log(updateArray);
        setArray(updateArray);
    };

    return (
        <div>
            <form onSubmit={handleSubmit}>
                <input type="text" name="arrayVal" onChange={e => setFormVal(e.target.value)} />
                <input type="submit" value="Submit" />
            </form>
            <div>
                {array.map((val, index) => <p key={index}>{val}</p>)}
            </div>
        </div>
    );
};

你也可以看到这个 [not] 工作:https : //codesandbox.io/s/p3n327zn3q

有没有人对为什么 handleSubmit 函数中的 setArray 不会自动导致组件重新渲染有任何建议?

2个回答

代替

let updateArray = array;

试试这个:

const updateArray = [...array];

https://codesandbox.io/embed/qxk4k3zmzq

因为 JS 中的数组是引用值,所以当你尝试使用 = 复制它时,它只会复制对原始数组的引用。

愚蠢的问题,但我无法找出谷歌的正确术语,[...array] 中的“...”是什么。顺便说一句,您的回答非常有帮助,谢谢!
2021-05-31 19:23:54
@cwmacken "Spread Operator" 正是您要找的。 developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/...
2021-06-11 19:23:54

相同的表现形式可能会发生类似的错误:

const [bought, setBought] = useState([])

...


bought.push(newItem)
setBought(bought)

要解决此问题,您需要使用

const newBought = [...bought, newItem] <- new reference
setBought(newBought) 
这正是原因。很好的解释!非常感谢蒂姆!
2021-06-18 19:23:54