javascript - 如何处理一组以上的单选按钮组 - reactjs

标签 javascript reactjs

我需要一点帮助或建议如何让它工作 - 我有不止一组单选按钮 第一组选中和取消选中并显示正确的输入,但是当我选中第二组时,第一组未选中并显示第二组的输入。 当选中第二组单选按钮时,我希望第一组单选按钮不取消选中。奇怪的是,这两个名称组都不同,这不是为什么它取消选中以前的组。认为选中的控件在选中时可以更好地用于跟踪。可以帮助解决我的问题。

    import React, { Component } from 'react';
import PropTypes from 'prop-types';

class MainForm extends Component {
  constructor(props) {
    super(props);
    this.state = {
      isChecked: null,
      isHidden: true,
      selectedOption: null,
      checkedState: null,
    };
  }

  handleCheckboxToggle(name, event) {
    if (event.target.checked) {
      this.setState({
        checkedState: event.target.value,
        isHidden: false,
        selectedOption: event.target.name,
      });
    } else {
      this.setState({
        isHidden: true,
        selectedOption: null,
      });
    }
  }

  renderCheckboxComponent(answer) {
    return (
      <div className="form__field--wrapper">
        {
        answer.map((item, index) => (
          <div key={item.id} className="form__checkbox form__checkbox--inline">
            <label className="form__checkbox required" htmlFor={`item.label-${item.name}-${index}`}>
              {item.label}
            </label>
            <input
              type="radio"
              id={`item.label-${item.name}-${index}`}
              name={item.name}
              value={item.value}
              onClick={e => this.handleCheckboxToggle(item.name, e)}
              checked={this.state.checkedState === item.value}
            />
            <span />
          </div>
          ))
        }
      </div>
    );
  }

  renderFieldInputComponent(fields, name) {
    return (
      <div>
        {
        fields.map(item => (
          this.state.selectedOption === item.name ?
            <div key={item.id} className="form__row">
              <label className="required" htmlFor={name}>
                {item.label}
              </label>
              <input
                type={item.type}
                id={name}
                name={name}
                required
                placeholder={item.placeholder}
              />
              <span />
            </div> : ''
          ))
        }
      </div>
    );
  }
  render() {
    const { data } = this.props;
    const { isHidden, isChecked } = this.state;
    return (
      <form>
        {
          data.map(item => (
            <div key={item.id} className="form__row form__row--checkbox">
              <p className="form__row--label">{item.name}</p>
              { this.renderCheckboxComponent(item.answer)}
              { !isHidden && this.renderFieldInputComponent(item.field, item.category)}
            </div>
          ))
        }
        <button type="button" className="btn btn--red">Update Preferences</button>
      </form>
    );
  }
}

MainForm.propTypes = {
  data: PropTypes.arrayOf(PropTypes.shape({
    id: PropTypes.number,
    name: PropTypes.string,
  }).isRequired).isRequired,
};

export default MainForm;

这是我正在处理的数据

   {  
  "Questions":[  
    {  
      "id":1,
      "name":"Email",
      "category":"emailPermission",
      "answer":[  
        {  
          "id":10,
          "label":"Yes",
          "value":"emailPermissionYes",
          "name":"emailPermission",
          "checked": true
        },
        {  
          "id":11,
          "label":"No",
          "value":"emailPermissionNo",
          "name":"emailPermission",
          "checked": true
        }
      ],
      "field":[
        {
          "id": 12, 
          "type": "email", 
          "name": "emailPermission", 
          "label": "Enter your email address",
          "placeholder": "example@email.com",
          "required": false
        }
      ]
    },
    {  
      "id":2,
      "name":"Post",
      "category":"postPermission",
      "answer":[  
        {  

          "id": 21,
          "label":"Yes",
          "value":"postPermissionYes",
          "name":"postPermission",
          "checked": true
        },
        {  
          "id": 22,
          "label":"No",
          "value":"postPermissionNo",
          "name":"postPermission",
          "checked": false
        }
      ],
      "field":[
        {
          "id": 23, 
          "type": "text",
          "name": "postPermission", 
          "label": "Postcode", 
          "placeholder": "SE1 7TP",
          "required": true
        }
      ]
    },
}

最佳答案

错误不在于您如何处理 name,而在于您如何处理选中状态。

每当选中一个单选按钮时,this.state.checkedState 就会更改为当前选中的单选按钮的值。

这意味着当您选择问题 2 中的单选按钮时,您最终会得到类似于 {checkedState: 'postPermissionYes'} 的状态。

当 React 然后重新呈现所有复选框时,只有最近点击的复选框会通过 checked={this.state.checkedState === item.value} 测试。对于 checked={this.state.checkedState === item.value},之前点击的单选按钮将返回 false。

相反,我建议以稍微不同的方式处理 checkedState……

将每个 radio 组的值存储到一个状态属性中,您可以为每个 radio 组使用 name 值。

这意味着您会将状态存储为:

this.state = {
    emailPermission: null,
    postPermission: null,
    // other properties would go here as well...
}

您的处理程序如下所示:

handleCheckboxToggle(name, event) {
    this.state[name] = event.target.value;
}

最后, radio 将确定 checked 属性如下:

checked={this.state[item.name] === item.value}

希望对您有所帮助!

关于javascript - 如何处理一组以上的单选按钮组 - reactjs,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50438144/

相关文章:

javascript - ReactJS组件什么时候写 "function"?

javascript - Marionette Layout 切换策略

javascript - AJAX:如何读取 JSON 数据

javascript - 大多数 "react"方式有多个不同的渲染

css - 设置 Material UI 选择/下拉宽度

reactjs - 可以在每次渲染时取消订阅并重新订阅我的所有 @Lexical/react 命令监听器吗?

reactjs - Jest + Typescript 如何测试 React 组件中的方法?

javascript - 如何根据另一个复选框选择取消选中一个复选框?

javascript - 如何从字符串的开头和结尾删除特定字符?

reactjs - 容器化的webpack-dev-server不响应文件更改