zoukankan      html  css  js  c++  java
  • [BS-19]更改UITextField的placeholder文字颜色的5种方法

    更改UITextField的placeholder文字颜色的5种方法

     

    想要达到的目标是:一个页面上有多个UITextField,当用户聚焦某textField时,该文本框的placeholder的文字会灰色变为白色,当文本框失去焦点时,placeholder颜色从白色再变回灰色。

    1.放置UILabel

    最简单最笨的方法是在每个textField里放一个UILabel来充当placeholder,当该textField聚焦时,让placeholder的文字会灰色变为白色,失焦后从白色再变回灰色。这种方法需要对每个UILabel和TextField拖线,通过监听键盘通知或者UITextField的代理来获悉textField是否聚焦,然后写一堆if语句来判断。

    2.修改textField.attributedPlaceholder属性

    //通过NSAttributedString来更改placeholder颜色。此种方法比较麻烦的是,需要知道页面上所有的textField什么时候聚焦,什么时候失焦(有两种方法:A.监听键盘弹出的通知  B.通过UITextField的代理方法textFieldDidBeginEditing),然后再判断哪个是白色,哪个是灰色。如果页面上textField非常多,就需要写很多的if语句。

        NSMutableAttributedString *attrString = [[NSMutableAttributedString alloc]initWithString:@"手机号" attributes:@{NSForegroundColorAttributeName:[UIColor whiteColor]}];

        self.phoneTextField.attributedPlaceholder = attrString;

    3. 利用UITextField的子类重写drawPlaceholderInRect:方法

       具体实现见代码:

    //该方法的好处是不用获取Xib中textField的引用,不用拖线,直接将Xib中textField的class改为自定义类即可。以后有任何textField想要改变placeholder的颜色,直接定义为该类即可。但还是需要自己监控UITextField是否聚焦。
    
    #import "WZCustomPlaceholderTextField.h"
    
    @implementation WZCustomPlaceholderTextField
    /**
     @interface NSString(NSStringDrawing)  NSString的分类
     - (CGSize)sizeWithAttributes:(nullable NSDictionary<NSString *, id> *)attrs NS_AVAILABLE(10_0, 7_0);
     - (void)drawAtPoint:(CGPoint)point withAttributes:(nullable NSDictionary<NSString *, id> *)attrs NS_AVAILABLE(10_0, 7_0);
     - (void)drawInRect:(CGRect)rect withAttributes:(nullable NSDictionary<NSString *, id> *)attrs NS_AVAILABLE(10_0, 7_0);
     @end
     */
    - (void)drawPlaceholderInRect:(CGRect)rect {//rect代表该自定义textField的frame/rect
    //因为placeholder属于NSString类型,所有的NSString都有drawInRect方法,但此方法似乎只在draw开头方法中有效
        [self.placeholder drawInRect:CGRectMake(0, 10, rect.size.width, rect.size.height) withAttributes:@{
                                                                                                           NSForegroundColorAttributeName:[UIColor whiteColor],
                                                                                                           NSFontAttributeName:[UIFont systemFontOfSize:15]
                                                                                                           }];
        
    }
    
    
    - (void)drawRect:(CGRect)rect {//rect代表该自定义textField的frame/rect
        [super drawRect:rect]; //调用父类UITextField的drawRect方法,将自定义尺寸传进去。必须调用父类
      
    }
    
    @end

    4.利用UITextField的子类重写drawRect:方法,在drawRect中通过[self.placeholder drawInRect:]来进行设置。

    5.通过KVC向UITextField隐藏的内部实例变量_placeholderLabel设值。

    利用runtime打印出UITextField所有的实例变量,发现有个叫_placeholderLabel的内部实例变量,在自定义类中通过KVC设值。此方法好处是:利用KVC设值方便简洁,而且可以写在任何位置。本例中我们重写becomeFirstResponder:和resignFirstResponder方法来监控UITextField是否聚焦,然后在其中利用KVC设值。

    //  WZTextField.m
    
    // 利用runtime打印出UITextField所有的实例变量,发现有个叫_placeholderLabel的内部实例变量,在自定义类中通过KVC设值。
    //
    
    #import "WZTextField.h"
    
    @implementation WZTextField
    //调用顺序1 (从xib创建时调用)
    - (instancetype)initWithCoder:(NSCoder *)aDecoder {
        if (self = [super initWithCoder:aDecoder]) {
        }
        return self;
    }
    //调用顺序2 (从xib创建时调用)
    - (void)awakeFromNib {
    
    }
    
    //调用顺序3 (无论xib还是纯代码创建都会调用)
    - (void)drawRect:(CGRect)rect {
        [super drawRect:rect];
        self.tintColor = self.textColor; //设置光标颜色和文字颜色一样
    }
    
    - (BOOL)becomeFirstResponder {
        [self setValue:[UIColor whiteColor] forKeyPath:@"_placeholderLabel.textColor"];
        return [super becomeFirstResponder];
    }
    
    - (BOOL)resignFirstResponder {
        [self setValue:[UIColor grayColor] forKeyPath:@"_placeholderLabel.textColor"];
        return [super resignFirstResponder];
    }
    
    @end

     

    iOS开发者交流群:180080550
  • 相关阅读:
    MySQL 4.1x 中文乱码效果
    linux内核中的“捏造化”
    Ubuntu开发者峰会在布拉格举行
    Decode 函数的用法
    Solaris 10拆卸jdk1.6及点窜成默许JDK
    教你编写高机能的mysql语法
    DirectShow9.0在vs2005中存在的问题解决
    Unicode,unicoidebig,Asci,UTF8文件read和write
    自已写了个GDI类,实现了相对路径载入任意类型的图片函数,并加一个在CRECT矩形上贴图的函数(5月25日写)
    两种解析EDIT控件上文本的方式
  • 原文地址:https://www.cnblogs.com/stevenwuzheng/p/5483332.html
Copyright © 2011-2022 走看看