UITextField, UITextView长度限制

//UITextField长度的限制

[self.nameTextFieldaddTarget:selfaction:@selector(textFieldDidChange:)forControlEvents:UIControlEventEditingChanged];


#define kMaxNameLength  (10)

- (void)textFieldDidChange:(UITextField *)textField

{

    if (textField == self.nameTextField) {

        NSString *toBeString = textField.text;

//        NSString *lang = [[UITextInputMode currentInputMode] primaryLanguage]; //键盘输入模式(有警告,改为下面一行)

        NSString *lang = [textField.textInputModeprimaryLanguage];// 键盘输入模式

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

            UITextRange *selectedRange = [textField markedTextRange];

            //获取高亮部分

            UITextPosition *position = [textField positionFromPosition:selectedRange.startoffset:0];

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

            if (!position) {

                if (toBeString.length > kMaxNameLength) {

                    textField.text = [toBeStringsubstringToIndex:kMaxNameLength];

                }

            }

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

            else{

                

            }

        }

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

        else{

            if (toBeString.length > kMaxNameLength) {

                textField.text = [toBeStringsubstringToIndex:kMaxNameLength];

            }

        }

    }

}


//UITextView的长度限制

为了限制uitextview输入的字符数,一般采取如下做法:

- (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range

 replacementText:(NSString *)text

{

    //判断输入的字符,是否超过界限

    NSString *str = [NSString stringWithFormat:@"%@%@", textView.text, text];

    if (str.length > kMaxLen)

    {

        textView.text = [str substringToIndex:kMaxLen];

        return NO;

    }

    return YES;

}

 但是,在汉语拼音输入状态下,如果有键盘联想汉字输入,则无法回调到该函数,所以可以一直联想输入下去,做不到限制字符数量的目的,为了解决这个问题,我们在textViewDidChange进行限制。

- (void)textViewDidChange:(UITextView *)textView

{

    if ( textView.text.length > kMaxLen)

    {

        textView.text = [textView.text substringToIndex:kMaxLen];

    }

 }

此时,如果在拼音状态下输入会有crash ,因为汉语拼音状态下,联想出的汉字等待用户选择,在用户选择前的状态下,不能改变textView.text。解决办法:

- (void)textViewDidChange:(UITextView *)textView

{

    if (textView.markedTextRange == nil && textView.text.length > kMaxLen)  //加上 textView.markedTextRange == nil判断,当此属性为nil时,代表不在这种联想输入等待确定状态。

    {

        textView.text = [textView.text substringToIndex:kMaxLen];

    }

 }


附带一个网页链接,但是这个方法我还没有实验过,查找资料时看到的。

http://www.techjini.com/blog/2014/10/27/maximum-length-for-uitextfield-with-t9-keyboard-on-ios/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值