作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何仅使用正则表达式在reactjs中允许文本框中的数字?
最佳答案
基本思想是:
使用controlled component (使用输入字段的 value 和 onChange 属性),并在 onChange 句柄内检查输入的值是否是正确的数字。仅当输入的值是有效数字时才更新状态。
为此,请使用此正则表达式:/^[0-9\b]+$/;
onChange 处理程序将是:
onChange(e){
const re = /^[0-9\b]+$/;
// if value is not blank, then test the regex
if (e.target.value === '' || re.test(e.target.value)) {
this.setState({value: e.target.value})
}
}
工作示例:
class App extends React.Component{
constructor(){
super();
this.state = {value: ''};
this.onChange = this.onChange.bind(this)
}
onChange(e){
const re = /^[0-9\b]+$/;
if (e.target.value === '' || re.test(e.target.value)) {
this.setState({value: e.target.value})
}
}
render(){
return <input value={this.state.value} onChange={this.onChange}/>
}
}
ReactDOM.render(<App/>,document.getElementById('app'))
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script>
<div id='app'/>
关于reactjs - 如何在reactjs中只允许文本框中出现数字?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43067719/
我是一名优秀的程序员,十分优秀!