react中antd文本框限制输入中文方式
方式一:
使用 replace 方法和正则表达式 /[^\u4e00-\u9fa5]/g 来过滤掉了输入字符串中的非中文字符。然后再对过滤后的字符进行正则验证,如果符合要求则更新状态值
import React, { useState, useEffect } from 'react';
import { Input } from 'antd';
const ChineseInput = () => {
const [value, setValue] = useState('');
const handleInputChange = e => {
const reg = /[\u4e00-\u9fa5]/g; // 只允许中文字符
const inputValue = e.target.value.replace(/[^\u4e00-\u9fa5]/g, ''); // 过滤掉输入的非中文字符
if (reg.test(inputValue)) {
setValue(inputValue);
}
else{
setValue('');
}
};
return <Input value={value} onChange={handleInputChange} />;
};
export default ChineseInput;方式二:
将 value 属性的值与实际输入值进行分离处理
增加了一个名为 displayValue 的新状态,用于控制输入框的显示值。在handleInputChange方法中,将输入框的实际值 inputValue 赋值给 value 状态,并将其也赋值给 displayValue 状态。如果输入的值不符合要求,将使用 e.target.value 替代它,以便让用户看到未被过滤的实际输入值。
另外,还实现了一个名为 handleInputBlur 的新方法。该方法在输入框失去焦点时被触发,将 displayValue 的值更新为正确的 value 状态值。
import React, { useState } from 'react';
import { Input } from 'antd';
const ChineseInput = () => {
const [value, setValue] = useState('');
const [displayValue, setDisplayValue] = useState('');
const handleInputChange = e => {
const reg = /[\u4e00-\u9fa5]/g;
const inputValue = e.target.value.replace(/[^\u4e00-\u9fa5]/g, '');
if (reg.test(inputValue)) {
setValue(inputValue);
setDisplayValue(inputValue);
} else {
setDisplayValue(e.target.value);
}
};
const handleInputBlur = () => {
setDisplayValue(value);
};
return <Input value={displayValue} onChange={handleInputChange} onBlur={handleInputBlur} />;
};
export default ChineseInput;不足:以上两个方法都有个弊端,第二次输入中文后会把之前的删除掉
以上就是react中antd文本框限制输入中文方式的详细内容,更多关于react antd文本框输入限制的资料请关注脚本之家其它相关文章!
相关文章
关于antd tree和父子组件之间的传值问题(react 总结)
这篇文章主要介绍了关于antd tree 和父子组件之间的传值问题,是小编给大家总结的一些react知识点,本文通过一个项目需求实例代码详解给大家介绍的非常详细,需要的朋友可以参考下2021-06-06
高性能React开发React Server Components详解
ReactServerComponents通过服务器端渲染、自动代码分割等技术,实现了高性能的React开发,它解决了客户端数据请求链式延迟、敏感数据暴露风险等问题,提供了更好的用户体验和安全性,本文介绍高性能React开发React Server Components详解,感兴趣的朋友一起看看吧2025-03-03


最新评论