プロパティを定義したいのですが、プロパティが省略されたコンポーネントである必要があります。
いくつかのプロパティを持つ検証コンポーネントがあります:
リーリー入力コンポーネントがあります。
リーリーそこで、InputProps.validations は Validation でなければならないと定義したいのですが、値 prop は省略します。
は次のように使用する必要があります:
ああああP粉4251197392024-04-04 09:27:11
ここで何を達成したいのかが 完全に明確ではないので、おそらく何かが欠けていると思います...
ただし、prop が特定のプロパティを持つコンポーネントである必要があることを直接指定することはできません。 は可能ですが、validations を指定します。<ValidationProps, 'value'/> を省略し、{React.cloneElement(props.validations, {value})} に置き換えます
入力で <validation check={props.validations} value={value}/>
をインスタンス化するだけです
更新:
2 つのコンポーネント (入力と検証) 間に依存関係を持たせたくない場合は、両方によってインポートされる 3 番目のモジュールでプロパティを共有しない限り、props インターフェース間にも依存関係を持たせることはできません。
この場合、
validations: (value) => ReactElement のように、さらに抽象化して検証をレンダリング プロップにすることができます。その後、以前と同様に使用できますが、「太い矢印」構文が追加されています
リーリー
の代わりに validations(value)
を呼び出してインスタンス化します。
これ