在 React 组件中设置条件 onClick 行为



我正在处理一个组件,其中按钮(类型为"提交"的输入字段(一旦单击就会提交数据。但是,我想引入一种保护措施,以便在输入字段为空时在屏幕上显示警报。

认为这将与组件属性的工作方式相同,我尝试了以下内容的变体,但没有太多运气:

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);
}

最新更新