我有一个简单的形式,可以接收名字和姓氏,并且需要删除字符串开头和结尾的空格。我可以使用.trim()
方法执行此操作,但是由于它是一种形式,因此它不允许我写一个包含两个单词的名称(例如Ana Maria),因为它不允许我按空格键一句话的结尾。如何在字符串的两边删除空格,但仍然让我按空格并写多个单词?
这是组件:
export default function ScheduleInput(
{ label, required, onChange, value, ...extraProps },
) {
return (
<div className="item_container">
{label}:
{required &&
<span style={{ color: 'red' }}> *</span>
}
<br />
<input
type="text"
onChange={onChange}
value={value.trim()}
{...extraProps}
/>
</div>
);
}
答案 0 :(得分:4)
代替修剪onChange
,而是在onBlur
回调中进行此操作:
<input onBlur={this.props.formatInput} {...} />
可能看起来像这样的地方:
formatInput = (event) => {
const attribute = event.target.getAttribute('name')
this.setState({ [attribute]: event.target.value.trim() })
}