我构建了自己的 React 选择组件,并希望有一个选项可以将默认值设置为 disabled
该组件基本上如下所示:
<select
id={this.props.id}
name={this.props.name}
value={this.props.value}
defaultValue={this.props.default}
onClick={this.handleFieldClick}
onChange={this.handleFieldChange} >
<option value="" disabled={this.defaultDisabled ? true : false} >{this.props.defaultLabel}</option>
{ Object.keys(this.props.options).map((val, i) => (
<option key={i} value={val}>{this.props.options[val]}</option>
))}
</select>
这一行给我的问题如下:
<option value="" disabled={this.defaultDisabled ? true : false} >{this.props.defaultLabel}</option>
“禁用”选项仍然可以选择并呈现如下:
<option value="" selected="">Default Option</option>
我相信这是因为禁用选项的正确语法是<option disabled ></option>
,而不是<option disabled="true" ></option>
但是当我按如下方式格式化我的 JSX 时:
<option value="" {this.defaultDisabled ? "disabled" : ""} >{this.props.defaultLabel}</option>
我收到一个导致应用程序崩溃的错误。
在 React 中使用 JXS 有条件地将指令值写入标签和/或有条件地设置禁用选项的正确语法是什么?