我如何避免此警告'组件正在更改要控制的不受控制的输入。这很可能是由于...'
const AddItem = () => {
const [user] = useAuthState(auth);
const navigate = useNavigate();
const handleAddCar = (e) => {
e.preventDefault();
const carObj = {
name: e.target.name.value,
supplier: e.target.supplier.value,
email: user.email,
price: parseInt(e.target.price.value),
quantity: parseInt(e.target.quantity.value),
description: e.target.description.value,
img: e.target.image.value,
sold: parseInt(e.target.sold.value),
};
axios
.post("http://localhost:5000/car", carObj)
.then((response) => {
toast("Successfully Added");
});
e.target.reset();
};
return (
<div>
<Container>
<Row>
<div className="col-md-6 mx-auto">
<h2 className="my-5">Add A Car</h2>
<Form onSubmit={handleAddCar}>
<Form.Group className="mb-3" controlId="formBasicModel">
<Form.Label>Model</Form.Label>
<Form.Control type="text" name="name" required />
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicSupplier">
<Form.Label>Supplier</Form.Label>
<Form.Control type="text" name="supplier" required />
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicEmail">
<Form.Label>Email</Form.Label>
<Form.Control
type="email"
value={user.email}
readOnly
disabled
/>
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicPrice">
<Form.Label>Price</Form.Label>
<Form.Control type="number" name="price" required />
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicQuantity">
<Form.Label>Quantity</Form.Label>
<Form.Control type="number" name="quantity" required />
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicDescription">
<Form.Label>Description</Form.Label>
<br />
<textarea
className="w-100"
name="description"
required
></textarea>
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicImage">
<Form.Label>Image</Form.Label>
<Form.Control type="text" name="image" required />
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicImage">
<Form.Label>Sold</Form.Label>
<Form.Control type="number" name="sold" required />
</Form.Group>
<Button variant="primary" type="submit" className="w-100 fw-bold">
Add Car
</Button>
</Form>
</div>
</Row>
</Container>
</div>
);
};
我正在尝试通过设置一些默认值并需要所有输入字段的表单中添加MongoDB数据库中的项目。它正在正常工作,但在控制台上发出警告:“组件正在更改要控制的不受控制的输入。这可能是由于从未定义为定义值的价值更改而引起的,这不应发生。”
const AddItem = () => {
const [user] = useAuthState(auth);
const navigate = useNavigate();
const handleAddCar = (e) => {
e.preventDefault();
const carObj = {
name: e.target.name.value,
supplier: e.target.supplier.value,
email: user.email,
price: parseInt(e.target.price.value),
quantity: parseInt(e.target.quantity.value),
description: e.target.description.value,
img: e.target.image.value,
sold: parseInt(e.target.sold.value),
};
axios
.post("http://localhost:5000/car", carObj)
.then((response) => {
toast("Successfully Added");
});
e.target.reset();
};
return (
<div>
<Container>
<Row>
<div className="col-md-6 mx-auto">
<h2 className="my-5">Add A Car</h2>
<Form onSubmit={handleAddCar}>
<Form.Group className="mb-3" controlId="formBasicModel">
<Form.Label>Model</Form.Label>
<Form.Control type="text" name="name" required />
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicSupplier">
<Form.Label>Supplier</Form.Label>
<Form.Control type="text" name="supplier" required />
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicEmail">
<Form.Label>Email</Form.Label>
<Form.Control
type="email"
value={user.email}
readOnly
disabled
/>
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicPrice">
<Form.Label>Price</Form.Label>
<Form.Control type="number" name="price" required />
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicQuantity">
<Form.Label>Quantity</Form.Label>
<Form.Control type="number" name="quantity" required />
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicDescription">
<Form.Label>Description</Form.Label>
<br />
<textarea
className="w-100"
name="description"
required
></textarea>
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicImage">
<Form.Label>Image</Form.Label>
<Form.Control type="text" name="image" required />
</Form.Group>
<Form.Group className="mb-3" controlId="formBasicImage">
<Form.Label>Sold</Form.Label>
<Form.Control type="number" name="sold" required />
</Form.Group>
<Button variant="primary" type="submit" className="w-100 fw-bold">
Add Car
</Button>
</Form>
</div>
</Row>
</Container>
</div>
);
};
I am trying to add an item in mongodb database by a form where I set some default value and required all input field. It is working properly but getting a warning on console "A component is changing an uncontrolled input to be controlled. This is likely caused by the value changing from undefined to a defined value, which should not happen."
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您的问题在这里:
您可以看到您将此组件的值设置为user..email,使其成为受控的输入(通常通过状态传递该值并从父组件中控制)。
一个不受控制的组件组件本身处理值。
我猜想您的
用户
对象(或至少是电子邮件参数)不确定,然后通过某种类型的API调用填充。您要么需要始终具有
user.email
在渲染此输入时可用的参数(例如,将输入包装在检查中,因此仅在user.email.email!==未定义时才呈现,或添加了一个寄存器电子邮件当用户对象首先初始化时),或者不太理想地为该值不确定时提供值。 (例如value = {user.email ??' - '}
)Your problem is here:
You can see you're setting the value of this component to user.email, making it a controlled input (where the value is passed in, and controlled from a parent component usually via a state).
an uncontrolled component is - basically - one where the value is not passed in, and the component itself deals with the value.
I'd guess that your
user
object (or the email parameter at least) is undefined to begin with, and then populates via an API call of some kind.you either need to always have
user.email
parameter available when this input is rendered (eg. wrap the input in a check so it only renders when user.email !== undefined or add in a placeholder email param when the user object is first initialised), or less ideally supply a value for when the value is undefined. (eg.value={user.email ?? '-'}
)