【问题标题】:How to Create Custom Dropdown Field Component with Redux-Form V6?如何使用 Redux-Form V6 创建自定义下拉字段组件?
【发布时间】:2016-10-16 20:47:27
【问题描述】:

我有一个应用程序会很重,我想要尽可能多的控制,同时使用尽可能少的依赖项。为此,我想利用 redux-form v6 的自定义 Field 组件 API 并制作一堆我可以随意放入的自定义组件。其中一个组件是下拉选择。

问题是自定义下拉组件没有连接到状态,即使它呈现正常。

在文档中,示例完成如下:

<Field name="favoriteColor" component="select">
  <option></option>
  <option value="#ff0000">Red</option>
  <option value="#00ff00">Green</option>
  <option value="#0000ff">Blue</option>
</Field>

我正在寻找一种即插即用的方法,我可以在其中放入一个组件,并将一组数据输入到 props 中:

Form.js

      <div className="form-group">
        <label htmlFor="dropDownSelect">Select an Option</label>
        <Field
          name="dropDownSelect"
          component={DropDownSelect}
          people={people}
          className="form-control"
        >
        </Field>
      </div>

DropDownSelect.js:

import React from 'react';

import styles from './styles.css';

class DropDownSelect extends React.Component { // eslint-disable-line react/prefer-stateless-function
  renderSelectOptions = (person) => {
    return (
      <option key={person} value={person}>{person}</option>
    );
  }

  render() {
    return (
      <select>
        {this.props.people.map(this.renderSelectOptions)}
      </select>
    );
  }
}


export default DropDownSelect;

当我检查 Redux DevTools 时,与下拉列表交互时,该字段的值永远不会填充:

我为这两个字段选择了一个值,但只有“effDate”填充了一个值,而“dropDownSelect”仍然是一个没有值的注册字段。

编辑:

根据这个例子,我想这样做的方法是:

function DropDownSelect(person) {
  return (
    <option key={person} value={person}>{person}</option>
  );
}

export default DropDownSelect;


      <div className="form-group">
        <label htmlFor="dropDownSelect">Select an Option</label>
        <Field
          name="dropDownSelect"
          component="select"
          // component={DropDownSelect}
          // people={people}
          className="form-control"
        >
          {people.map(DropDownSelect)}
        </Field>

这目前有效,但如果我可以将其实现为一个完全独立的组件(如初始问题中所述),那将是理想的,因此我可以在该字段依赖于其他字段的情况下利用生命周期挂钩.

【问题讨论】:

    标签: javascript reactjs html-select redux-form


    【解决方案1】:

    要制作处理下拉选择的单独自定义组件,我需要包含“输入”道具以将其连接到表单缩减器:

    自定义组件:

    /**
    *
    * DropDownSelect
    *
    */
    
    import React from 'react';
    
    import styles from './styles.css';
    
    class DropDownSelect extends React.Component { // eslint-disable-line react/prefer-stateless-function
    
      renderSelectOptions = (person) => (
        <option key={person} value={person}>{person}</option>
      )
    
      render() {
        const { input, label } = this.props;
        return (
          <div>
            {/* <label htmlFor={label}>{label}</label> */}
            <select {...input}>
              <option value="">Select</option>
              {this.props.people.map(this.renderSelectOptions)}
            </select>
          </div>
        );
      }
    }
    
    // function DropDownSelect(person) {
    //   return (
    //     <option key={person} value={person}>{person}</option>
    //   );
    // }
    
    DropDownSelect.propTypes = {
      people: React.PropTypes.array,
      input: React.PropTypes.object,
      label: React.PropTypes.string,
    };
    
    export default DropDownSelect;
    

    字段:

          <div className="form-group">
            <label htmlFor="dropDownSelect">Select an Option</label>
            <Field
              name="dropDownSelect"
              // component="select"
              label="dropDownSelect"
              component={DropDownSelect}
              people={people}
              className="form-control"
            >
              {/* {people.map(DropDownSelect)} */}
            </Field>
          </div>
    

    【讨论】:

    • 如何对错误进行自定义渲染。例如添加类似这样的内容以显示输入存在错误。 {touched &amp;&amp; error &amp;&amp; (&lt;div role="alert" className="error"&gt;Error!&lt;/div&gt;)}
    • 如何禁用 redux 中的下拉字段?
    • @BharathMb disabled 属性由 HTML 原生支持,可以像任何其他属性一样放入。在此示例中,您可以通过 Fielddisabled 作为道具传递,并将其深入到 &lt;select&gt; 标记中,例如:&lt;select {...input} disabled={true}&gt;...&lt;/select&gt;
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-10-09
    • 1970-01-01
    • 2017-09-21
    • 1970-01-01
    • 2016-09-11
    • 2021-06-12
    相关资源
    最近更新 更多