javascript - 这是在 React 中更改对象状态变量的最安全、最正确的方法吗?
问题描述
以下代码有效,即成功更新对象状态变量:
import { useState } from 'react'
import './App.css';
function App() {
const [config, setConfig] = useState({
status: "online",
maxFiles: 99
});
const addConfigEntry = () => {
setConfig(n => {
const n2 = { ...n };
n2.errors = 0;
return n2;
})
};
return (
<div className="App">
<button onClick={addConfigEntry}>Add a Entry</button>
<ul>
{Object.entries(config).map((entry, index) => {
return (
<li key={index}>{entry[0]} = {entry[1]}</li>
)
})}
</ul>
</div>
);
}
export default App;
但是我从 TypeScript 收到了这个警告,这让我认为这不是更新对象变量的最佳方式:
是否有更正确、更符合 React 的方式来更新对象变量?
附录
请注意,这不起作用(回复评论):
setConfig({ ...config, errors: 0 }); // will not be added!
setConfig({ ...config, errors2: 0 });
解决方案
当你说,
const [config, setConfig] = useState({
status: "online",
maxFiles: 99
});
TypeScript 根据您传递的初始状态对象推断配置的类型。所以,它认为config
看起来像:
type InferredConfig = {
status: string;
maxFiles: number;
}
请注意,解释类型中没有errors
,这就是您看到错误的原因。所以,我们需要明确地告诉类型。
您需要定义适当type
的 . 这是一种方式:
import { useState } from 'react'
import './App.css';
// 1. We are defining the type, that *may* have errors prop
type Config = {
status: string;
maxFiles: number;
errors?: number;
}
function App() {
// 2. tell `useState` that it manages an object of type `Config`
const [config, setConfig] = useState<Config>({
status: "online",
maxFiles: 99
});
const addConfigEntry = () => {
setConfig(n => {
const n2 = { ...n };
n2.errors = 0; // 3. No error
return n2;
})
};
return (
<div className="App">
<button onClick={addConfigEntry}>Add a Entry</button>
<ul>
{Object.entries(config).map((entry, index) => {
return (
<li key={index}>{entry[0]} = {entry[1]}</li>
)
})}
</ul>
</div>
);
}
export default App;
推荐阅读
- hive - 插入覆盖是否会删除配置单元中的数据和分区?
- python - 如何在 PyQT5 中随窗口大小改变显示大小?
- javascript - (jQuery) 将变量内容克隆到 Div
- nlp - 如何使用 conllu python 库保存编辑的 .conllu 文件
- java - 将对象分配给对象
- javascript - Javascript Regex 测试字符串是否在分隔行上只有数字
- android - 使用意图时如何将DatabaseReference传递给android中的类?
- android - 如何限制android播放器并行播放多个媒体文件?
- json - 使用 Perl 模块 LWP::Authen::OAuth2 创建 Google Team Drive
- javascript - 使用 CSHTML MVC 中的模型创建具有预定义列的动态表