个人在开发当中发现在用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判断输入长度的更多相关文章

  1. 五、HTML判断输入长度,体会字体颜色变化

    <!doctype html><html lang="en"> <head> <meta charset="UTF-8" ...

  2. textField 判断输入长度限制

    - (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementS ...

  3. js判断输入字符串长度(汉字算两个字符,字母数字算一个)

    js判断输入字符串长度(汉字算两个字符,字母数字算一个) 文本输入时,由于数据库表字段长度限制会导致提交失败,因此想到了此方法验证. 废话不多说上代码: <html> <head&g ...

  4. 编写Java程序,判断输入的三条长度的边,是否能构成三角形

    需求说明: 编写Java程序,判断输入的三条长度的边,是否能构成三角形. (三角形第三边大于两边之和小于两边之差) 实现代码: package test; import java.util.Scann ...

  5. iOS- UITextField限制输入长度

    限制输入长度的问题,在这里完美的解决了! //先创建一个textField 和 一个button. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 ...

  6. Shell脚本中判断输入参数个数的方法投稿:junjie 字体:[增加 减小] 类型:转载

    Shell脚本中判断输入参数个数的方法 投稿:junjie 字体:[增加 减小] 类型:转载   这篇文章主要介绍了Shell脚本中判断输入参数个数的方法,使用内置变量$#即可实现判断输入了多少个参数 ...

  7. linux脚本:shell, 判断输入参数的个数(命令行)

    if [ $# != 3 ] ; thenecho "USAGE: $0 from to"echo " e.g.: $0 ~/oucaijun/from ~/oucaij ...

  8. 更好地限制一个UITextField的输入长度

    要限制一个UITextField的输入字数,首先想到的应该是通过 UITextFieldDelegate 的代理方法来限制: - (BOOL)textField:(UITextField *)text ...

  9. javascript限定输入textarea输入长度

    <textarea  id="content" onkeyup="limitLength(this.value,'512','content')"> ...

随机推荐

  1. C# dev开发过程中的山炮问题汇总

    1. 后台注册控件,页面form提交,后台获取控件方法  Request.Form["name"]:

  2. FTP服务器原理

    21.1 FTP服务器原理   使用明码传输方式,且有相当多的安全危机历史.因此一般使用功能较少的vsftpd这个软件.   21.1.1 FTP功能简介   有以下功能 文档传输与管理 不同等级的用 ...

  3. Nginx内置变量以及日志格式变量参数详解

    $args #请求中的参数值 $query_string #同 $args $arg_NAME #GET请求中NAME的值 $is_args #如果请求中有参数,值为"?",否则为 ...

  4. mysql ERROR 1062: ALTER TABLE causes auto_increment resequen

    当我用Navicat尝试修改已有记录的mysql数据表的主键为自动增长时,报出以下错误 1602 ALTER TABLE causes auto_increment resequencing, res ...

  5. DataSnap 2009 系列之三 (生命周期篇)

    DataSnap 2009 系列之三 (生命周期篇) DataSnap 2009的服务器对象的生命周期依赖于DSServerClass组件的设置 当DSServer启动时从DSServerClass组 ...

  6. nagios二次开发(四)---nagios监控原理和nagios架构简介

    nagios监控原理 下面根据上面摘自网络的原理图对nagios的监控原理进行一下简单的说明: 1.nagios通过nsca进行被动监控.那么什么是被动监控呢?被动监测:就是指由被监测的服务器主动上传 ...

  7. 使用Nginx镜像代理.NET Core MVC

    1.获取microsoft/dotnet镜像 docker pull registry.cn-hangzhou.aliyuncs.com/cjx/tutorial 如果有问题确认已经使用阿里云镜像加速 ...

  8. Ruby-递归和尾递归

    递归和迭代的区别 递归: 1)递归就是在过程或函数里面调用自身; 2)在使用递归时,必须有一个明确的递归结束条件,称为递归出口. 迭代: 利用变量的原值推算出变量的一个新值.如果递归是自己调用自己的话 ...

  9. nginx重启

    ps aux | grep nginx 查找 主进程 号 kill 9666 /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.co ...

  10. 把cmd信息中的正常和异常输出分别输出到不同txt文件中

    场景一: 1.大量滚动信息容纳不下,在小黑屏中被冲刷掉. 2.希望把正常输出和异常输出分别输出到不同地方. 相关命令 一共有4个输出到文件的命令,现以jar命令打war包举例说明: 命令 说明 举例  ...