iOStextFiled判断输入长度
个人在开发当中发现在用textField的代理方法
-(BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
if (textField.text.length > 5) {
textField.text = [textField.text substringToIndex:5];
return;
}
}
中判断长度大小时,键盘中联想出来的文字还是可以输入到textField中。
比如,你的限制是5,输入框已经是5个字了,联想的字是 ‘电话’还可以输入进去。
这个时候可以使用给textField加通知解决
[self.TextField addTarget:self action:@selector(addTextFieldEditChanged:) forControlEvents:UIControlEventEditingChanged];
在通知的方法中判断。
//长度判断
-(void)addSpecsTextFieldEditChanged:(UITextField *)textField{ NSString *lang = [[UITextInputMode currentInputMode] primaryLanguage]; // 键盘输入模式
if ([lang isEqualToString:@"zh-Hans"]) { // 简体中文输入,包括简体拼音,健体五笔,简体手写 }
// 中文输入法以外的直接对其统计限制即可,不考虑其他语种情况
else{ if ([textField isEqual:self.countText] ) { if ([textField.text floatValue] > 999) { textField.text = [textField.text substringToIndex:4];
[self.toast makeToast:@"库存不能超过999!" duration:2.0 position:CSToastPositionCenter];
return;
}
}
}
if ([textField isEqual:self.specsText] ) { if (textField.text.length > 20) {
textField.text = [textField.text substringToIndex:20];
[self.toast makeToast:@"规格不能超过20位字符!" duration:2.0 position:CSToastPositionCenter];
return;
}
} UITextRange *selectedRange = [textField markedTextRange];
//获取高亮部分
UITextPosition *position = [textField positionFromPosition:selectedRange.start offset:0];
// 没有高亮选择的字,则对已输入的文字进行字数统计和限制
if (!position) { if ([textField isEqual:self.priceText] ) { if ([textField.text floatValue] >= 1000) { textField.text = [textField.text substringToIndex:5];
[self.toast makeToast:@"价格不能超过999.99!" duration:2.0 position:CSToastPositionCenter];
return;
}
}
if ([textField isEqual:self.unitText] ) {
if (textField.text.length > 4) {
textField.text = [textField.text substringToIndex:4];
[self.toast makeToast:@"单位不能超过4位字符!" duration:2.0 position:CSToastPositionCenter];
return;
}
} }
// 有高亮选择的字符串,则暂不对文字进行统计和限制
else{ }
}
//限制小数点
-(BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{ if ([ToolClass stringContainsEmoji:string]) { //过滤表情
return NO;
}
if (textField == self.priceText) {
if ([textField.text rangeOfString:@"."].location == NSNotFound) {
self.isHaveDian = NO;
}
if ([string length] > 0) { unichar single = [string characterAtIndex:0];//当前输入的字符
if ((single >= '0' && single <= '9') || single == '.') {//数据格式正确 //首字母不能为0和小数点
if([textField.text length] == 0){
if(single == '.') {
[textField.text stringByReplacingCharactersInRange:range withString:@""];
return NO;
} } //输入的字符是否是小数点
if (single == '.') {
if(!self.isHaveDian)//text中还没有小数点
{
self.isHaveDian = YES;
return YES; }else{
[textField.text stringByReplacingCharactersInRange:range withString:@""];
return NO;
}
}else{
if (self.isHaveDian) {//存在小数点 //判断小数点的位数
NSRange ran = [textField.text rangeOfString:@"."];
if (range.location - ran.location <= 2) {
return YES;
}else{ [self.toast makeToast:@"小数点后只能输入2位!" duration:2 position:CSToastPositionCenter];
return NO;
}
}else{
return YES;
}
}
}else{//输入的数据格式不正确 [textField.text stringByReplacingCharactersInRange:range withString:@""];
return NO;
}
}
else
{
return YES;
} }
return YES;
}
//过滤表情
+ (BOOL)stringContainsEmoji:(NSString *)string { __block BOOL returnValue = NO; [string enumerateSubstringsInRange:NSMakeRange(0, [string length]) options:NSStringEnumerationByComposedCharacterSequences usingBlock:^(NSString *substring, NSRange substringRange, NSRange enclosingRange, BOOL *stop) { const unichar hs = [substring characterAtIndex:0]; if (0xd800 <= hs && hs <= 0xdbff) { if (substring.length > 1) { const unichar ls = [substring characterAtIndex:1]; const int uc = ((hs - 0xd800) * 0x400) + (ls - 0xdc00) + 0x10000; if (0x1d000 <= uc && uc <= 0x1f77f) { returnValue = YES; }else{ returnValue = YES; } } } else if (substring.length > 1) { const unichar ls = [substring characterAtIndex:1]; if (ls == 0x20e3) { returnValue = YES; }else{ returnValue = YES; } } else { if (0x2100 <= hs && hs <= 0x27ff) { if (10123 <= hs && hs <= 10130) { returnValue = NO; }else{ returnValue = YES; } } else if (0x2B05 <= hs && hs <= 0x2b07) { returnValue = YES; } else if (0x2934 <= hs && hs <= 0x2935) { returnValue = YES; } else if (0x3297 <= hs && hs <= 0x3299) { returnValue = YES; } else if (hs == 0xa9 || hs == 0xae || hs == 0x303d || hs == 0x3030 || hs == 0x2b55 || hs == 0x2b1c || hs == 0x2b1b || hs == 0x2b50) { returnValue = YES; } } }]; return returnValue;
}
/**
*返回字符位数
*传进来字符串计算出字符串中总字符数,其中一个汉字表示2位字符,数字
*字母表示一位字符
*/
+ (NSInteger) computeStringCharCount:(NSString *)string{ NSInteger count = ; for (int i=; i < string.length; i++){
NSRange range = NSMakeRange(i, ); NSString *subString=[string substringWithRange:range];
const char *cString=[subString UTF8String];
if ([self stringContainsEmoji:string]) {
[SRMessage infoMessage:@"不能输入表情!"];
return count;
}
if (strlen(cString)==)
{
count = count + ;
}else if(strlen(cString)==)
{
count = count + ;
}
} return count;
}
iOStextFiled判断输入长度的更多相关文章
- 五、HTML判断输入长度,体会字体颜色变化
<!doctype html><html lang="en"> <head> <meta charset="UTF-8" ...
- textField 判断输入长度限制
- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementS ...
- js判断输入字符串长度(汉字算两个字符,字母数字算一个)
js判断输入字符串长度(汉字算两个字符,字母数字算一个) 文本输入时,由于数据库表字段长度限制会导致提交失败,因此想到了此方法验证. 废话不多说上代码: <html> <head&g ...
- 编写Java程序,判断输入的三条长度的边,是否能构成三角形
需求说明: 编写Java程序,判断输入的三条长度的边,是否能构成三角形. (三角形第三边大于两边之和小于两边之差) 实现代码: package test; import java.util.Scann ...
- iOS- UITextField限制输入长度
限制输入长度的问题,在这里完美的解决了! //先创建一个textField 和 一个button. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 ...
- Shell脚本中判断输入参数个数的方法投稿:junjie 字体:[增加 减小] 类型:转载
Shell脚本中判断输入参数个数的方法 投稿:junjie 字体:[增加 减小] 类型:转载 这篇文章主要介绍了Shell脚本中判断输入参数个数的方法,使用内置变量$#即可实现判断输入了多少个参数 ...
- linux脚本:shell, 判断输入参数的个数(命令行)
if [ $# != 3 ] ; thenecho "USAGE: $0 from to"echo " e.g.: $0 ~/oucaijun/from ~/oucaij ...
- 更好地限制一个UITextField的输入长度
要限制一个UITextField的输入字数,首先想到的应该是通过 UITextFieldDelegate 的代理方法来限制: - (BOOL)textField:(UITextField *)text ...
- javascript限定输入textarea输入长度
<textarea id="content" onkeyup="limitLength(this.value,'512','content')"> ...
随机推荐
- WLAN频段的选择
WLAN(无线局域网)通过射频技术,将设备之间互联.当前应用于WLAN组网的有WIFI,蓝牙等.蓝牙工作在2.4GHZ的ISM(工业.科研.医疗)频段,功率等级分为0dBm,10dBm,20dBm:发 ...
- python迭代器,生成器,装饰器,context模块
迭代器iteration 是访问集合元素的一种方式,只能往前不能往后迭代器的特点:1,访问者不需要关注迭代器内部结构,只需通过next()不断取下一个内容2,访问不能回退3,循环较大数据集合时,省内存 ...
- Python实现插件机制——自动import一个目录下的所有.py文件
假设有这样一个目录结构: /src main.py /plugins __init__.py a.py ...
- egrep 及扩展正则表达式
grep -E 表示支持扩展的正则表达式 grep -E = egrep 一.字符匹配: 扩展模式下的字符匹配与基本正则表达式的字符匹配相同,如: . 表示任意单个字符 [] 表示范围内人任意单个字符 ...
- ngx.lua中遇到的小问题2
用lua+drizzle在数据库中插入数据失败(不能访问数据库) 后面发现原来是nginx配置文件中的drizzle模块部分最后多了一行 content_by_lua 'ngx.say(" ...
- Loadrunner ---集合点设置
测试场景,实现用户登录的200并发: 1.录制登录退出脚本,且登录退出放aciton中 2.在登录的地方设置集合点 设置集合点有如下4中方式: 1)在要插入集合点的地方,右击鼠标按如下图操作:
- 运行Java cmd程序 找不到或无法加载主类怎么解决
//这个问题原因有以下几种,但是和环境变量并没有太大的关系 //能够执行java 和 javac 就证明你的环境变量已经配置好了,其实 classpath 可以不配置 //假如有如下文件:H:\cod ...
- asp.net LINQ实现数据分页
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...
- asp.net LINQ防止SQL注入式攻击
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...
- asp.net GDI+ 绘制椭圆 ,弧线,扇形
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...