Wie füge ich Eigenschaften basierend auf Bedingungen in React-Komponenten dynamisch hinzu?
P粉665427988
2023-08-20 14:54:00
<p>Gibt es eine Möglichkeit, Eigenschaften nur dann zu einer React-Komponente hinzuzufügen, wenn bestimmte Bedingungen erfüllt sind? </p>
<p>Ich muss dem Formularelement basierend auf den Bedingungen im nachgerenderten Ajax-Aufruf erforderliche und readOnly-Attribute hinzufügen, weiß aber nicht, wie ich dieses Problem lösen kann, da <code>readOnly="false"< /code> ist völlig anders als das Weglassen von Attributen. </p>
<p>Das folgende Beispiel soll veranschaulichen, was ich möchte, aber es funktioniert nicht. </p>
<blockquote>
<p>(Analysefehler: unerwarteter Bezeichner)</p>
</blockquote>
<pre class="brush:js;toolbar:false;">function MyInput({isRequired}) {
return <input classname="foo" {isRequired ? "required" : ""} />
}
</pre>
<p><br /></p>
juandemarco的答案通常是正确的,但这里还有另一种选择。
按照您的喜好构建一个对象:
使用spread进行渲染,还可以选择传递其他props。
显然,对于某些属性,如果传递给React的值不是真值,React会智能地省略该属性。例如:
将会得到:
更新:如果有人对此如何发生以及为什么发生感到好奇,你可以在ReactDOM的源代码中找到详细信息,具体位于DOMProperty.js文件的第30行和167行。