我正在尝试使用自定义组件作为 react-select 中的输入字段。由于我需要验证,因此我尝试将 HTML5 oninvalid
(onInvalid
在 JSX 中)用于我的输入标记,并为oninvalid
. 但是,我无法将消息作为props传递给我在 select 中设置的组件。下面是我的代码。
输入.js
import React from "react";
import { components } from "react-select";
export default class Input extends React.Component {
constructor(props) {
super(props);
}
componentDidMount() {
console.log("component mounted");
}
setInvalidMessage = event => {
event.target.setCustomValidity("Custom Message");
};
render() {
if (this.props.isHidden) {
return <components.Input {...this.props} />;
}
return (
<components.Input
{...this.props}
required
onInvalid={this.setInvalidMessage}
/>
);
}
}
例子.js
import React from "react";
import Input from "./Input";
import Select from "react-select";
import { colourOptions } from "./docs/data";
const InputBoxWithText = props => {
return <Input {...props} />;
};
export default () => (
<form>
<Select
closeMenuOnSelect={true}
components={{ InputBoxWithText }}
options={colourOptions}
/>
<input type="submit" />
</form>
);
如果我在 components 属性中传递 Input,我会在 Input.js 中得到硬编码的消息。如果我通过 InputBoxWithText 我根本看不到 Input 安装。
索引.js
import React from 'react';
import ReactDOM from 'react-dom';
import Example from './example';
ReactDOM.render(
<Example />,
document.getElementById('root')
);
任何人都可以让我知道我做错了什么。