iOS中修改UITextField占位符字体颜色的方法总结

时间:2022-04-30 15:00:27

前言

最近学了uitextfield控件, 感觉在里面设置占位符非常好, 给用户提示信息, 于是就在想占位符的字体和颜色能不能改变呢?下面是小编的一些简单的实现,有需要的朋友们可以参考。

修改uitextfield的占位符文字颜色主要有三个方法:

1、使用attributedplaceholder属性

?
1
@property(nullable, nonatomic,copy) nsattributedstring  *attributedplaceholder ns_available_ios(6_0); // default is nil

2、重写drawplaceholderinrect方法

?
1
- (void)drawplaceholderinrect:(cgrect)rect;

3、修改uitextfield内部placeholderlaber的颜色

?
1
[textfield setvalue:[uicolor graycolor] forkeypath@"placeholderlaber.textcolor"];

以下是详细的实现过程

给定场景,如在注册登录中,要修改手机号和密码textfield的placeholder的文字颜色。

效果对比

iOS中修改UITextField占位符字体颜色的方法总结
使用前

iOS中修改UITextField占位符字体颜色的方法总结
使用后

使用attributedplaceholder

自定义gylloginregistertextfield类,继承自uitextfield;实现awakefromnib()方法,如果使用storyboard,那么修改对应的uitextfield的customclassgylloginregistertextfield即可

具体代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#import "gylloginregistertextfield.h"
@implementation gylloginregistertextfield
 
- (void)awakefromnib
{
 self.tintcolor = [uicolor whitecolor];  //设置光标颜色
 
 //修改占位符文字颜色
 nsmutabledictionary *attrs = [nsmutabledictionary dictionary];
 attrs[nsforegroundcolorattributename] = [uicolor whitecolor];
 self.attributedplaceholder = [[nsattributedstring alloc] initwithstring:self.placeholder attributes:attrs];
}
 
@end

重写drawplaceholderinrect方法

与方法一同样,自定义gylloginregistertextfield,继承自uitextfield,重写drawplaceholderinrect方法,后续相同

代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#import "gylloginregistertextfield.h"
 
@implementation gylloginregistertextfield
 
- (void)awakefromnib
{
 self.tintcolor = [uicolor whitecolor];  //设置光标颜色
}
 
- (void)drawplaceholderinrect:(cgrect)rect
{
 nsmutabledictionary *attrs = [nsmutabledictionary dictionary];
 attrs[nsforegroundcolorattributename] = [uicolor whitecolor];
 attrs[nsfontattributename] = self.font;
 
 //画出占位符
 cgrect placeholderrect;
 placeholderrect.size.width = rect.size.width;
 placeholderrect.size.height = rect.size.height;
 placeholderrect.origin.x = 0;
 placeholderrect.origin.y = (rect.size.height - self.font.lineheight) * 0.5;
 [self.placeholder drawinrect:placeholderrect withattributes:attrs];
 
 //或者
 /*
 cgpoint placeholderpoint = cgpointmake(0, (rect.size.height - self.font.lineheight) * 0.5);
 [self.placeholder drawatpoint:placeholderpoint withattributes:attrs];
 */
}
 
@end

修改uitextfield内部placeholderlaber的颜色

使用kvc机制,找到uitextfield内部的修改站位文字颜色的属性:placeholderlaber.textcolor

代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
#import "gylloginregistertextfield.h"
@implementation gylloginregistertextfield
 
- (void)awakefromnib
{
 self.tintcolor = [uicolor whitecolor];  //设置光标颜色
 
 //修改占位符文字颜色
 [self setvalue:[uicolor graycolor] forkeypath@"placeholderlaber.textcolor"];
}
 
@end

第三种方法比较简单,建议可以将此封装:扩展uitextfield,新建category,添加placeholdercolor属性,使用kvc重写setget方法。

总结

以上就是这篇文章的全部内容了,希望能对大家开发ios有所帮助,如果有疑问大家可以留言交流。