React Native 实现过滤中文,只能输入数字和小数点

本文介绍了如何在React Native中使用TextInput组件实现过滤,仅允许用户输入数字和小数点。通过onTextChange事件和isNaN函数进行验证,确保输入合法。对于eslint校验问题,也提供了解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

React Native 实现过滤中文,只能输入数字和小数点


在使用React Native 的TextInput时,有时需要过滤中文,只能让用户输入数字和小数点。
但是TextInput方法本身没有相应的api,所以解决办法为,在onTextChange事件中手动过滤中文,再设置keyboardType=‘numeric’,用户输入时就会弹出数字键盘。

onTextChange代码:


	<TextInput 
		value={this.state.text}
		onTextChange={(val) =>{
      		text = isNaN(val) ? '' : val;
			this.setState({text});
		}
		keyboardType='numeric'
	/>

isNaN示例:

isNaN(NaN);       // true
isNaN(undefined); // true
isNaN({});        // true

isNaN(true);      // false
isNaN(null);      // false
isNaN(37);        // false

// strings
isNaN("37");      // false: 可以被转换成数值37
isNaN("37.37");   // false: 可以被转换成数值37.37
isNaN("37,5");    // true
isNaN('123ABC');  // true:  parseInt("123ABC")的结果是 123, 但是Number("123ABC")结果是 NaN
isNaN("");        // false: 空字符串被转换成0
isNaN(" ");       // false: 包含空格的字符串被转换成0

// dates
isNaN(new Date());                // false
isNaN(new Date().toString());     // true

isNaN("blabla")   // true: "blabla"不能转换成数值
                  // 转换成数值失败, 返回NaN

拿不准isNaN的同学,可以看这里

有些同学使用了eslint语法校验,编译不通过的话可以参照以下代码:

    text = Number.isNaN(Number(val)) ? '' : val;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值