我正在处理一个组件,其中按钮(类型为"提交"的输入字段(一旦单击就会提交数据。但是,我想引入一种保护措施,以便在输入字段为空时在屏幕上显示警报。
认为这将与组件属性的工作方式相同,我尝试了以下内容的变体,但没有太多运气:
onClick={props.inputText === ''
?
alert("Text cannot be blank.")
:
(e => props.onSubmit(props.inputText))}/>
我宁愿不在onSubmit函数中运行检查,以便尽可能隔离对存储的更新(我遵循React-Redux结构(。
知道JSX是否以及如何处理这样的情况吗?
这应该有效:
onClick={() => { props.inputText === '' ?
alert("Text cannot be blank.") :
props.onSubmit(props.inputText) }}
您正在将值分配给onClick event
,但 onclick 需要一个函数。为了实现这一点,将所有逻辑包装在一个函数体中。
这样写:
onClick={ e => {
props.inputText === '' ?
alert("Text cannot be blank.")
:
props.onSubmit(props.inputText)}
}
/>
或
onClick={this.onClick.bind(this)/>
onClick(e){
if(props.inputText === ''){
alert("Text cannot be blank.");
return;
}
props.onSubmit(props.inputText);
}