TextFiled限制字符串长度问题

在第三方键盘加入之后,对于字数限制的处理不再像之前那么简单了

纯数字、字符输入(不包括粘贴)这样的字数限制还是相对比较简单的,你可以用两种方法进行处理

第一种是textfield的delegate实现:

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string {

if (range.length + range.location > textField.text.length) {

return NO;

}

NSUInteger newLength = textField.text.length + string.length - range.length;

return newLength<=kMaxCharacterCount;

}

第二种是注册一个通知,在textfield编辑时做处理:

首先你在viewDidLoad中注册通知

[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(textFiledEditChanged:) name:UITextFieldTextDidChangeNotification object:self.shopName];

再实现通知里面的方法,在超过最大值时,取最大的字数

if (self.shopName.text.length > kMaxCharacterCount) {

self.shopName.text = [self.shopName.text substringToIndex:kMaxCharacterCount];

}

但是,在中文的限制上面情况就复杂了,当时在调试的时候,因为使用的是第三方键盘,所以当时没有发现问题,但是在使用系统键盘的时候,一下子就蛋疼了….

下面我开始分析一下,两者的区别:1、第三方键盘在输入字符时,一般是不会将字符直接输入到textfield中,而是将字符显示在它自己的view上方,但是系统键盘会直接输入到textfield中,而且它会占2个字符长度,比如你输入”abcd”,在textfield中显示的是”a b c d”,并且”a b c d”是处在高亮中的,并不算是真正输入到textfield中,所以我们不应把高亮的字符计算在内,我们应该计算真正输入的字符

2、如果我们使用的是delegate做处理的时候,系统中文输入的时候会有联想,但是联想的那个字并不会调用delegate,比如你输入一个”你”,在系统的联想里面可能会出现”的”,”们”这样的联想,但是你选择”的”的时候,delegate并不会调用,(尼玛….),我猜想联想输入应该不算做keyboard所触发的事件,所以他并不会触发delegate,但是如果你注册的是通知,他倒是会调用,(还好有救)

另外提醒一下,有时候在自测输入的时候,要考虑全面,比如粘贴这也是一种输入,当时没考虑,我也是跪了

好了,分析了主要的区别下面我们就来看看具体怎么实现吧~

在实现注册通知方法里面:

#pragma mark - UITextViewDelegate

- (void)textViewDidChange:(UITextView *)textView {

if (textView.text.length == 0) {

self.recommendTips.hidden = NO;

}else{

self.recommendTips.hidden = YES;

}

NSString *toBeString = textView.text;

NSString *lang = self.textInputMode.primaryLanguage; // 键盘输入模式

if ([lang isEqualToString:@"zh-Hans"]) { // 简体中文输入,包括简体拼音,健体五笔,简体手写

UITextRange *selectedRange = [textView markedTextRange];

//获取高亮部分

UITextPosition *position = [textView positionFromPosition:selectedRange.start offset:0];

// 没有高亮选择的字,则对已输入的文字进行字数统计和限制

if (!position || !selectedRange) {

if (toBeString.length > 200) {

textView.text = [toBeString substringToIndex:200];

}

}

// 有高亮选择的字符串,则暂不对文字进行统计和限制

else{

}

}

// 中文输入法以外的直接对其统计限制即可,不考虑其他语种情况

else{

if (toBeString.length > 200) {

textView.text = [toBeString substringToIndex:200];

}

}

}

首先,我们根据键盘的输入模式进行区分,英文的比较简单就和上面一样,直接取最大的字符数就好了,在中文输入的时候,我们用markedTextRange方法获取到当前的光标位置,再用textField positionFromPosition:selectedRange.start offset:0获取到高亮部分,然后判断是否有高亮,这个时候系统会调用两次通知方法,第一次是将高亮的字符输入,第二次是将高亮的字符转换成中文输入(这个时候就没有高亮了,然后再取最大的字符数),但是在iOS7的设备上测试时发现,position都不会为nil,在iOS8以上都正常,但是获取到光标的range,却是正常的

NS_CLASS_AVAILABLE_IOS(3_2) @interface UITextRange : NSObject

@property (nonatomic, readonly, getter=isEmpty) BOOL empty;    //  Whether the range is zero-length.

@property (nonatomic, readonly) UITextPosition *start;

@property (nonatomic, readonly) UITextPosition *end;

@end

我们可以看到系统的UITextRange,有两个变量,一个是start,一个是end,这正是对于的高亮区域!

所以既然position不能使用,那我们干脆就使用range,通过判断range的存在,来对文字进行限制处理。(粘贴也适用)

结果也是棒棒的!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,076评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,658评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,732评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,493评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,591评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,598评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,601评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,348评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,797评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,114评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,278评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,953评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,585评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,202评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,180评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,139评论 2 352

推荐阅读更多精彩内容