更改UITextFiled中placeholder的颜色

  1. 对placeholder的分析

    1. 随意创建一个UITextFiled, 然后通过打断点的方式, 在调试区查看TextFiled的内部属性(通常用这种方法偷看苹果隐藏起来的属性)

      • 通过对属性的排查, 我们发现placeholder本质上就是一个UILabel, 这个隐藏的变量名称为_placeholderLabel
      • 而对于一个UILable, 我们都知道应该怎样修改他的字体颜色, 但是别忘了这个属性是水果隐藏起来的, 私有API, 正常情况下是不会让我们访问到的
      • 因此我们就要使用苹果的黑魔法之一: KVC
    2. KVC作为苹果的黑魔法之一, 平时最大的用处就是用来给变量赋值, 并且最nb的地方就在于他能访问到隐藏起来的私有变量: 来重温一下setValue: forKeyPath:的实现流程

      • 首先, 他会根据你所提供的Key, 去方法调用对象的内部, 需找是否有Key对应的setter方法, 如果有就直接调用方法给这个Key附上Value的值
      • 如果没有setter方法, 就会查找有没有与Key名称相同的变量, 如果找到了, 就直接给这个变量赋值
      • 如果没有找到Key的同名变量, 那么就会继续查找有没有与Key同名, 但是带下划线的成员变量, 即_Key, 如果找到了, 就直接赋值
      • 如果此时还是没有找到的话, KVC就会调用setValue: forUndefinedKey:这个方法, 然后抛出异常, 程序崩溃
      • 这里有一个小技巧, 我们经常使用字典数组给模型赋值, 然后转化为模型数组, 但是从服务器返回的所有数据, 我们并不需要每一个, 往往只是需要其中几个, 而这时使用KVC往往会出现问题, 这时我们可以重写setValue: forUndefinedKey这个方法但是不写任何实现, 这样我们就成功的干掉了系统的方法, 不让他再给我们抛出异常, 但强烈建议, 不要随便干掉系统的方法, 除非你知道自己在干什么
  2. 使用KVC来修改placeholder的颜色

    1. 一行代码搞定placeholder的颜色, 利用KVC来访问他的私有变量

      [self setValue:[UIColor lightGrayColor] forKeyPath:@"_placeholderLabel.textColor"];

    2. 如果你想在UITextFiled编辑时, 编辑完成时展现不同的颜色, 就需要给TextFiled添加监听方法

      • UITextFiled属于UIControl的子类, 也就是说他可以使用[]addTarget: action: forControlEvent]这个方法来增加监听方法

      • 监听开始编辑: UIControlEventEditingDidBegin

      • 监听编辑结束: UIControlEventEditingDidEnd

      • 为上面两个监听事件分别绑定不同的方法, 然后再使用KVC更改placeholder的颜色即可

          - (void)awakeFromNib { // 默认情况下的颜色
              
              [self setValue:[UIColor lightGrayColor] forKeyPath:@"_placeholderLabel.textColor"];
              
              [self addTarget:self action:@selector(textBeginEdit) forControlEvents:UIControlEventEditingDidBegin];
              [self addTarget:self action:@selector(textEndEdit) forControlEvents:UIControlEventEditingDidEnd];
          }
          
          - (void)textBeginEdit { // 开始编辑时的颜色
              
              [self setValue:[UIColor whiteColor] forKeyPath:@"_placeholderLabel.textColor"];
          }
          
          - (void)textEndEdit { // 结束编辑时的颜色
              
              [self setValue:[UIColor lightGrayColor] forKeyPath:@"_placeholderLabel.textColor"];
          }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 201,924评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,781评论 2 378
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,813评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,264评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,273评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,383评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,800评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,482评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,673评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,497评论 2 318
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,545评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,240评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,802评论 3 304
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,866评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,101评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,673评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,245评论 2 341

推荐阅读更多精彩内容