带有 react-hook-form 的单选按钮

Posted

技术标签:

【中文标题】带有 react-hook-form 的单选按钮【英文标题】:Radio buttons with react-hook-form 【发布时间】:2021-08-10 01:55:57 【问题描述】:

我用 react-hook-form 创建了一个表单。它在控制台中正确记录“fullName”和“city”,但不是单选按钮。使用单选按钮,您会得到“null”的结果。

我的代码如下。

import React from 'react'
import './App.css';
import useForm from "react-hook-form";

function App() 
    const register, handleSubmit = useForm();

    function onSubmitButton(data) 
        console.log(data)
    

    return (
        <>
            <h1>Order weather</h1>
            <form onSubmit=handleSubmit(onSubmitButton)>
                <input
                    ...register("fullName")
                    type="text"
                    name="fullName"
                    placeholder="Name and surname"
                    id="name"
                />
                <input
                    ...register("city")
                    type="text"
                    name="city"
                    placeholder="City"
                    id="city"
                />
                <p>I would like to:</p>
                <label htmlFor="field-rain">
                    <input
                        ...register("rain")
                        type="radio"
                        name="weather"
                        value="rain"
                        id="field-rain"
                    />
                    Rain
                </label>
                <label htmlFor="field-wind">
                    <input
                        ...register("wind")
                        type="radio"
                        name="weather"
                        value="wind"
                        id="field-wind"
                    />
                    Lots of wind
                </label>
                <label htmlFor="field-sun">
                    <input
                        ...register("sun")
                        type="radio"
                        name="weather"
                        value="sun"
                        id="field-sun"
                    />
                    Sunny
                </label>
                <button type="submit">
                    Send
                </button>
            </form>
        </>
    );


export default App;

当我关闭name= "weather" 并检查按钮时,它确实将它放在控制台中,但它不应该允许我同时检查所有按钮。任何人都知道如何确保我可以将检查到控制台中的内容?

【问题讨论】:

如果您在label-元素内使用input-字段,则无需指定htmlFor 属性(或id 字段上的id 属性就此而言)。 【参考方案1】:

由于雨、风、太阳应该分配给相同的值,我们需要传递相同的参数来注册函数,如下所示

function App() 
    const register, handleSubmit = useForm();

    function onSubmitButton(data) 
        console.log(data)
    

    return (
        <>
            <h1>Order weather</h1>
            <form onSubmit=handleSubmit(onSubmitButton)>
                <input
                    ...register("fullName")
                    type="text"
                    name="fullName"
                    placeholder="Name and surname"
                    id="name"
                />
                <input
                    ...register("city")
                    type="text"
                    name="city"
                    placeholder="City"
                    id="city"
                />
                <p>I would like to:</p>
                <label htmlFor="field-rain">
                    <input
                        ...register("weather")
                        type="radio"
                        name="weather"
                        value="rain"
                        id="field-rain"
                    />
                    Rain
                </label>
                <label htmlFor="field-wind">
                    <input
                        ...register("weather")
                        type="radio"
                        name="weather"
                        value="wind"
                        id="field-wind"
                    />
                    Lots of wind
                </label>
                <label htmlFor="field-sun">
                    <input
                        ...register("weather")
                        type="radio"
                        name="weather"
                        value="sun"
                        id="field-sun"
                    />
                    Sunny
                </label>
                <button type="submit">
                    Send
                </button>
            </form>
        </>
    );


export default App;

我希望这能解决问题。

【讨论】:

哦,当然!我这是多么愚蠢的思维错误。谢谢!

以上是关于带有 react-hook-form 的单选按钮的主要内容,如果未能解决你的问题,请参考以下文章

取消选中带有 Material UI 的单选按钮

带有 React 的单选按钮

如何处理 ExpandableListView 中的单选按钮?

带有javascript的单选按钮

Android:保存单选按钮的状态

Python Tkinter 中的单选按钮值