iOS使用runtime修改文本框(TextField)的占位文字顏色
前言
在大家平時(shí)的開發(fā)中,有時(shí)候會(huì)遇到背景深色的界面上需要添加TextField,TextField默認(rèn)的占位顏色也是深灰色,比較難看清,這時(shí)候就需要修改展位文字的顏色,可是系統(tǒng)沒(méi)有提供相應(yīng)的方法,那么就需要我們自己來(lái)自定義了
修改后的效果
話不多說(shuō),下面上代碼:
// .h文件 #import <UIKit/UIKit.h> @interface UITextField (Placeholder) @property UIColor *placeholderColor; @end
// .m文件 #import "UITextField+Placeholder.h" #import <objc/message.h> NSString * const placeholderColorName = @"placeholderColor"; @implementation UITextField (Placeholder) + (void)load { // 獲取setPlaceholder Method setPlaceholder = class_getInstanceMethod(self, @selector(setPlaceholder:)); // 獲取bs_setPlaceholder Method bs_setPlaceholder = class_getInstanceMethod(self, @selector(bs_setPlaceholder:)); // 交換方法 method_exchangeImplementations(setPlaceholder, bs_setPlaceholder); } // OC最喜歡懶加載,用的的時(shí)候才會(huì)去加載 // 需要給系統(tǒng)UITextField添加屬性,只能使用runtime - (void)setPlaceholderColor:(UIColor *)placeholderColor { // 設(shè)置關(guān)聯(lián) objc_setAssociatedObject(self,(__bridge const void *)(placeholderColorName), placeholderColor, OBJC_ASSOCIATION_RETAIN_NONATOMIC); // 設(shè)置占位文字顏色 UILabel *placeholderLabel = [self valueForKeyPath:@"placeholderLabel"]; placeholderLabel.textColor = placeholderColor; } - (UIColor *)placeholderColor { // 返回關(guān)聯(lián) return objc_getAssociatedObject(self, (__bridge const void *)(placeholderColorName)); } // 設(shè)置占位文字,并且設(shè)置占位文字顏色 - (void)bs_setPlaceholder:(NSString *)placeholder { // 1.設(shè)置占位文字 [self bs_setPlaceholder:placeholder]; // 2.設(shè)置占位文字顏色 self.placeholderColor = self.placeholderColor; } @end
總結(jié)
以上就是iOS使用runtime修改文本框占位文字顏色的全部?jī)?nèi)容,希望對(duì)大家開發(fā)IOS能有所幫助,如果有疑問(wèn)大家可以留言交流。
- 總結(jié)iOS中runtime的使用
- iOS runtime forwardInvocation詳解及整理
- iOS runtime動(dòng)態(tài)添加方法示例詳解
- iOS通過(guò)Runtime實(shí)現(xiàn)友盟統(tǒng)計(jì)的實(shí)例代碼
- IOS Object-C 中Runtime詳解及實(shí)例代碼
- IOS 中runtime使用方法整理
- iOS利用Runtime實(shí)現(xiàn)友盟頁(yè)面數(shù)據(jù)統(tǒng)計(jì)的功能示例
- iOS runtime知識(shí)梳理
- iOS中Runtime的幾種基本用法記錄
- iOS Runtime詳解(新手也看得懂)
相關(guān)文章
iOS用AutoLayout實(shí)現(xiàn)分頁(yè)滾動(dòng)功能
這篇文章主要給大家介紹了關(guān)于iOS用AutoLayout實(shí)現(xiàn)分頁(yè)滾動(dòng)功能的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)各位iOS開發(fā)者們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06iOS實(shí)現(xiàn)自動(dòng)循環(huán)播放的banner實(shí)例詳解
輪播視圖通常也叫Banner,90%以上App都會(huì)用到的一個(gè)控件,網(wǎng)上有很多開源代碼,下面這篇文章主要給大家介紹了關(guān)于利用iOS如何實(shí)現(xiàn)自動(dòng)循環(huán)播放的banner的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下。2017-12-12iOS 讀取URL圖片并存儲(chǔ)到本地的實(shí)例
下面小編就為大家?guī)?lái)一篇iOS 讀取URL圖片并存儲(chǔ)到本地的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12iOS Xcode升級(jí)Xcode15報(bào)錯(cuò)SDK does not contain
這篇文章主要為大家介紹了iOS Xcode 升級(jí)Xcode15報(bào)錯(cuò): SDK does not contain 'libarclite'解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11Flutter?模型動(dòng)態(tài)化賦值研究分析
這篇文章主要為大家介紹了Flutter?模型動(dòng)態(tài)化賦值研究分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03iOS App開發(fā)中的UIStackView堆疊視圖使用教程
UIStackView是iOS9以來(lái)新增加的組件,使我們能夠?qū)IView子類對(duì)象進(jìn)行靈活排版,這里我們就來(lái)看一下iOS App開發(fā)中的UIStackView堆疊視圖使用教程2016-07-07