对于UITextField 使用过程中遇到的各种问题的一个总结

基本设置

  • 1.设置占位文字颜色

    • 1.NSAttributeplaceHolder:可以设置所有的占位文字的富文本属性

    • 2.NSMutableAttributePlaceHolder:可以设置部分或全部文字的富文本属性

    • 3.runtime获取私有属性:placeHolderLabel,

Ivar *ivars = class_copyIvarList([UITextField class],&count);//获取属性列表

[self setValue:[UICol grayColor] forKeyPath:@"_placeholderLabel.textColor"];//placeholderLabel是通过运行时获取到的私有属性

        . 4.重写 - (void)drawPlaceholderInRect:
   self.placeholder drawInRect: withAttributes...

1.1 设置光标颜色:setTintColor

1.2 设置点击时的颜色,就是需要监听到成为第一响应者,重写becomeFirstResponder,和resignFirstResponder

2.设置键盘:inputView,比如可以自定义表情键盘

3.设置键盘上面的功能按钮:inputAccesoryView,自定义,拖一个toolBar,toolBar上面加上item和弹簧控件

4.设置边框样式,只有设置了才会显示边框样式 text.borderStyle = UITextBorderStyleRoundedRect;

5.输入框中是否有个叉号,在什么时候显示,用于一次性删除输入框中的内容text.clearButtonMode = UITextFieldViewModeAlways;

6.每输入一个字符就变成点 用语密码输入text.secureTextEntry = YES;

7.再次编辑就清空text.clearsOnBeginEditing = YES

8.内容对齐方式text.textAlignment = UITextAlignmentLeft;

9.内容的垂直对齐方式 UITextField继承自UIControl,此类中有一个属性contentVerticalAlignmenttext.contentVerticalAlignment = UIControlContentVerticalAlignmentCenter;

10.设置为YES时文本会自动缩小以适应文本窗口大小.默认是保持原来大小,而让长文本滚动 textFied.adjustsFontSizeToFitWidth = YES;

11.设置键盘的样式text.keyboardType = UIKeyboardTypeNumberPad;

textField 的三种监听方式比较:

textField的代理方法只能监听到开始编辑和结束编辑,但是对于textField的值得改变,只能通过添加监听的方式解决啦.

一般来说有以下三种方式实现对textField的监听,但是各有利弊,所以使用哪种方式还需结合实际需求.



 //KVO监听(通过界面输入的时候监听不到),
    [self.field addObserver:self forKeyPath:@"text" options:NSKeyValueObservingOptionNew context:@"message"];

    //直接添加监听(通过代码插入的时候监听不到)
    [self.field addTarget:self action:@selector(valueChanged) forControlEvents:UIControlEventEditingChanged];

    //通知方式监听(通过代码插入的时候监听不到)
    [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(notiValueChanged) name:UITextFieldTextDidChangeNotification  object:self.field];

如何限定textField的输入长度


要限制一个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个字符的限制。

到了这里,我们可能会希望有个类似

  • (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];
      }

    }

    }










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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值