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')"> ...
 
随机推荐
- 解决ASP.Net第一次访问慢的处理(IIS8)
			
本篇经验以IIS8,Windows Server 2012R2做为案例. IIS8 运行在 Windows Server 2012 and Windows 8 版本以上的平台上. IIS中应用程序池和 ...
 - Scala学习笔记之伴生对象
			
所谓伴生对象, 也是一个Scala中的单例对象, 使用object关键字修饰. 除此之外, 还有一个使用class关键字定义的同名类, 这个类和单例对象存在于同一个文件中, 这个类就叫做这个单例对象的 ...
 - OpenVZ VPS加速方案–Final Speed
			
body,td { font-family: 微软雅黑; font-size: 10pt } OpenVZ VPS加速方案–Final Speed OpenVZ VPS加速方案–Final Spe ...
 - JQuery实现的模块交换动画效果
			
<!doctype html> <html> <head> <meta http-equiv="content-type" content ...
 - Elasticsearch升级1.5版本暴露jdk的bug
			
把测试环境的Elasticsearch升级到1.5.1版本,启动的时候报错: [root@node2 elasticsearch-1.5.1]# bin/service/elasticsearch s ...
 - LeetCode Bulb Switcher 319
			
变换灯泡颜色 There are n bulbs that are initially off. You first turn on all the bulbs. Then, you turn off ...
 - gridview填充剩下的空间
			
设置不要在控间中滑动: public class DeliverGridView extends GridView { public DeliverGridView(Context context, ...
 - $.grep(array, callback, [invert])过滤,常用
			
$.grep(array, callback, [invert])过滤,常用 解释: 使用过滤函数过滤数组元素.此函数至少传递两个参数(第三个参数为true或false,对过滤函数返回值取反,个人觉得 ...
 - 关于js中闭包的理解
			
1.以前很不理解js中闭包的概念及使用,下面来看一下 function foo() { var a = 123; var b = 456; return function () { return a; ...
 - oricle数据库关于定时