iOS改變UITextField占位文字顏色的三種方法
有時(shí),UITextField自帶的占位文字的顏色太淺或者不滿足需求,所以需要修改,而UITextField沒(méi)有直接的屬性去修改占位文字的顏色,所以只能通過(guò)其他間接方式去修改。
例如:系統(tǒng)默認(rèn)的占位文字顏色太淺

需要加深顏色,或者改變顏色
示例:

核心代碼
方法一:通過(guò)attributedPlaceholder屬性修改占位文字顏色
CGFloat viewWidth = self.view.bounds.size.width;
CGFloat textFieldX = 50;
CGFloat textFieldH = 30;
CGFloat padding = 30;
UITextField *textField = [[UITextField alloc] init];
textField.frame = CGRectMake(textFieldX, 100, viewWidth - 2 * textFieldX, textFieldH);
textField.borderStyle = UITextBorderStyleRoundedRect; // 邊框類(lèi)型
textField.font = [UIFont systemFontOfSize:14];
NSAttributedString *attrString = [[NSAttributedString alloc] initWithString:@"請(qǐng)輸入占位文字" attributes:
@{NSForegroundColorAttributeName:[UIColor redColor],
NSFontAttributeName:textField.font
}];
textField.attributedPlaceholder = attrString;
[self.view addSubview:textField];
方法二:通過(guò)KVC修改占位文字顏色
UITextField *textField1 = [[UITextField alloc] init]; textField1.frame = CGRectMake(textFieldX, CGRectGetMaxY(textField.frame) + padding, viewWidth - 2 * textFieldX, textFieldH); textField1.borderStyle = UITextBorderStyleRoundedRect; textField1.placeholder = @"請(qǐng)輸入占位文字"; textField1.font = [UIFont systemFontOfSize:14]; // "通過(guò)KVC修改占位文字的顏色" [textField1 setValue:[UIColor greenColor] forKeyPath:@"_placeholderLabel.textColor"]; [self.view addSubview:textField1];
方法三:通過(guò)重寫(xiě)UITextField的drawPlaceholderInRect:方法修改占位文字顏色
1、自定義一個(gè)TextField繼承自UITextField
2、重寫(xiě)drawPlaceholderInRect:方法
3、在drawPlaceholderInRect方法中設(shè)置placeholder的屬性
// 重寫(xiě)此方法
-(void)drawPlaceholderInRect:(CGRect)rect {
// 計(jì)算占位文字的 Size
CGSize placeholderSize = [self.placeholder sizeWithAttributes:
@{NSFontAttributeName : self.font}];
[self.placeholder drawInRect:CGRectMake(0, (rect.size.height - placeholderSize.height)/2, rect.size.width, rect.size.height) withAttributes:
@{NSForegroundColorAttributeName : [UIColor blueColor],
NSFontAttributeName : self.font}];
}
總結(jié):
1、當(dāng)我們使用純代碼創(chuàng)建UITextField時(shí),用第二種方法(KVC)修改占位文字顏色是最便捷的
2、當(dāng)我們使用XIB或者Storyboard創(chuàng)建UITextField時(shí),通過(guò)自定義UITextField,修改占位文字顏色是最適合的。
3、我們也可以在第三種重寫(xiě)方法中,通過(guò)結(jié)合第二種方法中的KVC修改屬性來(lái)實(shí)現(xiàn)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
IOS開(kāi)發(fā)之判斷兩個(gè)數(shù)組中數(shù)據(jù)是否相同實(shí)例詳解
這篇文章主要介紹了IOS開(kāi)發(fā)之判斷兩個(gè)數(shù)組中數(shù)據(jù)是否相同實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-02-02
解析iOS內(nèi)存不足時(shí)的警告以及處理過(guò)程
這篇文章主要介紹了iOS內(nèi)存不足時(shí)的警告以及處理過(guò)程,包括View Controller和生命周期等相關(guān)方面的知識(shí),需要的朋友可以參考下2015-10-10
iOS實(shí)現(xiàn)轉(zhuǎn)場(chǎng)動(dòng)畫(huà)的3種方法示例
這篇文章主要給大家介紹了關(guān)于iOS實(shí)現(xiàn)轉(zhuǎn)場(chǎng)動(dòng)畫(huà)的3種方法,文中通過(guò)示例代碼以及圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
iOS實(shí)現(xiàn)簡(jiǎn)單計(jì)算器小功能
這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)簡(jiǎn)單計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
IOS開(kāi)發(fā)中取消文本框輸入時(shí)的小鍵盤(pán)
這篇文章主要介紹了IOS開(kāi)發(fā)中取消文本框輸入時(shí)的小鍵盤(pán),需要的朋友可以參考下2015-05-05
iOS中模態(tài)Model視圖跳轉(zhuǎn)和Push視圖跳轉(zhuǎn)的需求實(shí)現(xiàn)方法
這篇文章主要介紹了iOS中模態(tài)Model視圖跳轉(zhuǎn)和Push視圖跳轉(zhuǎn)的需求實(shí)現(xiàn),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12

