美文网首页
textField&textView相关

textField&textView相关

作者: 旺仔Milk | 来源:发表于2017-07-31 17:49 被阅读7次

    - textField随输入文字判断个数(判断文字是否为空)

    #pragma mark- UITextFieldDelegate
    - (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string
    {
        
        NSMutableString * changedString=[[NSMutableString alloc]initWithString:textField.text];
        [changedString replaceCharactersInRange:range withString:string];
        
        if (changedString.length!=0) {
            self.navigationItem.rightBarButtonItem.enabled=YES;
        }else{
            self.navigationItem.rightBarButtonItem.enabled=NO;
        }
    
        return YES;
    }
    
    
    #pragma mark- UITextViewDelegate
    - (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text
    {
        NSMutableString * changedString=[[NSMutableString alloc]initWithString:textView.text];
        [changedString replaceCharactersInRange:range withString:text];
        
        if (changedString.length!=0) {
            self.navigationItem.rightBarButtonItem.enabled=YES;
        }else{
            self.navigationItem.rightBarButtonItem.enabled=NO;
        }
        
        return YES;
    }
    

    - 如何更好地限制一个UITextField的输入长度

    要限制一个UITextField的输入字数(参考链接),首先想到的应该是通过
    UITextFieldDelegate

    的代理方法来限制:

    - (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string; // return NO to not change text
    

    比如要设置字数限制为20:

    - (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
       if (textField == self.titleField) { 
            if (textField.length > 20) {
                return NO; 
              }
         }
       return YES;
    }
    

    但是这样的限制简单粗暴,可能会影响用户正常逻辑下的输入,比如输入了20个字符后,要退格回删字符。这时候我们可能会考虑“Detect backspace in UITextField”,比如简单地判断replacementString的长度是否为0。接着我们可能还会遇到用户已经输入20个字符了,这时候继续输入---不过是选择了部分文本进行替换-----无法进行了,这也妨碍了用户的正常操作,所以限制的代码版本可能会演进为:

    #pragma mark - UITextFieldDelegate- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
         if (textField == self.titleField) {
             if (string.length == 0) 
                return YES; 
                NSInteger existedLength = textField.text.length; 
                NSInteger selectedLength = range.length; 
                NSInteger replaceLength = string.length;
                if (existedLength - selectedLength + replaceLength > 20) { 
                    return NO; 
                    }
               } 
            return YES;
      }
    

    到这里可能会觉得基本大功告成了,但是当你输入19个字符后,第20个字符以中文汉字的形式继续输入,那么系统会在键盘上方提供后续的一系列联想词,你会发现通过这种方式可以连续选字输入从而突破20个字符的限制。WTF
    到了这里,我们可能会希望有个类似

    - (void)textFieldDidChange:(UITextField *)textField
    

    的回调方法,但可惜没有。当然,我们还可以通过

    - (void)textFieldDidEndEditing:(UITextField *)textField;
    

    回调方法在结束编辑的时候把文本截断,虽然在用户体验上会有点突兀。不过当我们点进去UITextField.h头文件里寻觅上述回调方法而不得时,可能会发现最下面有这么个消息通知名称:

    UIKIT_EXTERN NSString *const UITextFieldTextDidChangeNotification;
    

    不过,监听消息还要记得解除监听,通常我还习惯把监听消息的代码统一放在一个方法中,看起来有点“大动干戈”。所幸的是UITextField本身提供了相应的事件监听

    [textField addTarget:self action:@selector(textFieldDidChange:) forControlEvents:UIControlEventEditingChanged];
    

    这样就可以更好地限制输入长度:

    - (void)textFieldDidChange:(UITextField *)textField{ 
        if (textField == self.titleField) {
           if (textField.text.length > 20) {
               textField.text = [textField.text substringToIndex:20];
            }
         }
      }
    

    - textview实现点击return键让键盘隐藏的操作

    UITextFieldDelegate代理里面响应return键的回调:

    textFieldShouldReturn:
    

    但是 UITextView的代理UITextViewDelegate 里面并没有这样的回调。
    但是有别的方法可以实现:
    UITextViewDelegate里面有这样一个代理函数:

    - (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text
    

    这个函数的最后一个参数text代表你每次输入的的那个字,所以:

    - (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text{
        if ([text isEqualToString:@"\n"]){ //判断输入的字是否是回车,即按下return
            //在这里做你响应return键的代码
            [self.textView resignFirstResponder];
            return NO; //这里返回NO,就代表return键值失效,即页面上按下return,不会出现换行,如果为yes,则输入页面会换行
        }
    
        return YES;
    }
    

    判断中文预输入内容

    有是有 做搜索会有这样的需求,逐字搜索(实时搜索,打一个字搜一个字,但是打中文得时候预输入内容也会算作汉字进行输入)

    if (textField.markedTextRange != nil) {
                // 预输入内容不为空,不让搜索
                
                NSLog(@"text:%@", textField.text);
                return;
            } else {
                // 进行搜索操作
    }
    

    textView 赋值 文字无法显示 双击 textView 可显示

    关联 ios8, textView, 不显示
    text 录入没问题, 但是 外部赋值 不显示
    首先 项目中 使用的约束, 然后找了一圈 最后发现

    contentTV.textContainerInset = UIEdgeInsetsMake(5, -5, 5, 0)
    

    其 left 值是负数导致的, 因为是一个排列整齐的表单, 解决办法目前就是 将 frame整体向左移动(textView 本身有内边距)
    目前查看了 已有的测试机 所有机型, 只出现在 iOS8系统中, 如果有出现一样状况的同学 可以查看以下是不是写了这个属性

    切换明文/密文有多余空格

    如图,会有空白;


    image.png
    image.png

    解决方法

     func textFieldIsSecureTextEntry(bool:Bool) {
             print("是否睁眼睛",bool)
            contentTF.isSecureTextEntry = !bool
                // 密文切明文导致光标位移
                let oldText = self.contentTF.text;
                self.contentTF.text = "";
                self.contentTF.text = oldText;
        }
    

    二 切换到密文状态,再次编辑时,内容清空

    重现:1.切换明密文状态,最后在密文状态,再次编辑,输入任意字符,内容清空;
    2.其他textField获取焦点,再切回来(密文状态),内容清空

    解决方法:

     func textFieldIsSecureTextEntry(bool:Bool) {
             print("是否睁眼睛",bool)
            contentTF.isSecureTextEntry = !bool
                // 密文切明文导致光标位移
                let oldText = self.contentTF.text;
                self.contentTF.text = "";
                self.contentTF.text = oldText;
            if contentTF.isSecureTextEntry {
                self.contentTF.insertText(oldText!)
            }
        }
    

    相关文章

      网友评论

          本文标题:textField&textView相关

          本文链接:https://www.haomeiwen.com/subject/lkvrlxtx.html