UITextField的基本使用

UITextField的基本使用

  • 有时候光标距离textField的左边太近 想调节一下距离:
    // 设置文本框左边的内容
    UIView *leftView = [[UIView alloc] init];
    leftView.frame = CGRectMake(0, 0, 10, 0);
    textField.leftView = leftView;
    //模式设置为一直显示
    textField.leftViewMode = UITextFieldViewModeAlways;
  • 常见代理方法

     //是否允许开始编辑
    - (BOOL)textFieldShouldBeginEditing:(UITextField *)textField;
    
     //是否允许结束编辑
    - (BOOL)textFieldShouldEndEditing:(UITextField *)textField;
    
     // 是否允许用户输入文字
    - (BOOL)textField:(UITextField *)textField 
         shouldChangeCharactersInRange:(NSRange)range 
                     replacementString:(NSString *)string;
    
    // 文本框开始编辑的时候调用
    - (void)textFieldDidBeginEditing:(UITextField *)textField;
    
  • 键盘弹出时的notification

  • 弹出的通知名称

键盘状态改变的时候,系统会发出一些特定的通知
UIKeyboardWillShowNotification // 键盘即将显示
UIKeyboardDidShowNotification // 键盘显示完毕
UIKeyboardWillHideNotification // 键盘即将隐藏
UIKeyboardDidHideNotification // 键盘隐藏完毕
UIKeyboardWillChangeFrameNotification//键盘的位置尺寸即将发生改变
UIKeyboardDidChangeFrameNotification // 键盘的位置尺寸改变完毕
  • 通知中包含的有用的信息
系统发出键盘通知时,会附带一下跟键盘有关的额外信息(字典),字典常见的key如下:
UIKeyboardFrameBeginUserInfoKey // 键盘刚开始的frame
UIKeyboardFrameEndUserInfoKey // 键盘最终的frame(动画执行完毕后)
UIKeyboardAnimationDurationUserInfoKey // 键盘动画的时间
UIKeyboardAnimationCurveUserInfoKey // 键盘动画的执行节奏(快慢)

键盘弹出和消失的时候屏幕的改变

  • 在键盘弹出和消失的时候一般控制器的view会作出相应的改变,以便键盘不会遮挡住view
   - (void)viewDidLoad {
       [super viewDidLoad];
       // 监听键盘通知
       [[NSNotificationCenter defaultCenter] addObserver:self 
                                             selector:@selector(keyboardWillChangeFrame:) 
                                                 name:UIKeyboardWillChangeFrameNotification 
                                               object:nil];
   }

   - (void)keyboardWillChangeFrame:(NSNotification *)notification {
       // 取出键盘最终的frame
       CGRect rect = [notification.userInfo[UIKeyboardFrameEndUserInfoKey] CGRectValue];
    // 取出键盘弹出需要花费的时间
    double duration = [notification.userInfo[UIKeyboardAnimationDurationUserInfoKey] doubleValue];
    // 修改transform
    [UIView animateWithDuration:duration animations:^{
        CGFloat ty = [UIScreen mainScreen].bounds.size.height - rect.origin.y;
        self.view.transform = CGAffineTransformMakeTranslation(0, - ty);
    }];
} 

UITextField的编辑事件的监听

  • 通过UIControl的addTarget方法
[textField addTarget:target action:@selector(editingDidBegin) forControlEvents:UIControlEventEditingDidBegin];
[textField addTarget:target action:@selector(editingDidEnd) forControlEvents:UIControlEventEditingDidEnd];
  • 通过代理
- (void)textFieldDidBeginEditing:(UITextField *)textField{
}
- (void)textFieldDidEndEditing:(UITextField *)textField{
}
  • 通过通知
[[NSNotificationCenter defaultCenter] addObserver:self 
                                         selector:@selector(beginEditing) 
                                             name:UITextFieldTextDidBeginEditingNotification 
                                           object:textField];

[[NSNotificationCenter defaultCenter] addObserver:self 
                                         selector:@selector(endEditing) 
                                             name:UITextFieldTextDidEndEditingNotification 
                                           object:textField];

- (void)dealloc{
    [[NSNotificationCenter defaultCenter] removeObserver:self];
}

  • 重写UITextField的becomeFirstResponderresignFirstResponder方法
 //调用时刻 : 成为第一响应者(开始编辑\弹出键盘\获得焦点)
- (BOOL)becomeFirstResponder{
    return [super becomeFirstResponder];
}

//调用时刻 : 不做第一响应者(结束编辑\退出键盘\失去焦点)
- (BOOL)resignFirstResponder{
 return [super resignFirstResponder];
}

UITextField的常见需求

  • 更改光标的颜色
     textField.tintColor = [UIColor whiteColor];
    
  • 设置占位文字:设置placeholder或者attributedPlaceholder
  • 自定义占位文字颜色
  • 使用attributedPlaceholder进行设置
    NSMutableDictionary *attributes = [NSMutableDictionary dictionary];
    attributes[NSForegroundColorAttributeName] = [UIColor whiteColor];
    self.attributedPlaceholder = [[NSAttributedString alloc] initWithString:@"Placeholder" attributes:attributes];
    
  • 重写drawPlaceholderInRect方法
        //前提是先设置placeholder占位文字  否则这个方法不会走
      - (void)drawPlaceholderInRect:(CGRect)rect{
          // 文字属性
          NSMutableDictionary *attrs = [NSMutableDictionary dictionary];
          attrs[NSForegroundColorAttributeName] = [UIColor whiteColor];
          attrs[NSFontAttributeName] = self.font;
          CGPoint placeholderPoint = CGPointMake(0, (rect.size.height - self.font.lineHeight) * 0.5);
          [self.placeholder drawAtPoint:placeholderPoint withAttributes:attrs];
          // 画出占位文字
          //    CGRect placeholderRect;
          //    placeholderRect.size.width = rect.size.width;
          //    placeholderRect.size.height = self.font.lineHeight;
          //    placeholderRect.origin.x = 0;
          //    placeholderRect.origin.y = (rect.size.height - self.font.lineHeight) * 0.5;
          //    [self.placeholder drawInRect:placeholderRect withAttributes:attrs];
      }
    
  • 修改内部占位文字Label的文字颜色
[textField setValue:[UIColor grayColor] forKeyPath:@"placeholderLabel.textColor"];
  • 在有多个textfield的时候在聚焦的时候占位文字颜色是一种颜色,非聚焦的时候是另一种颜色:实现方式是在成为第一响应者的时候设置一次占位文字颜色,在市区第一响应者的时候设置一次占位文字颜色
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容