前言
最近学了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的文字颜色。
效果对比
使用attributedplaceholder
自定义gylloginregistertextfield类,继承自uitextfield;实现awakefromnib()方法,如果使用storyboard,那么修改对应的uitextfield的customclass为gylloginregistertextfield即可
具体代码如下:
|
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重写set和get方法。
总结
以上就是这篇文章的全部内容了,希望能对大家开发ios有所帮助,如果有疑问大家可以留言交流。
相关文章
- ASP.NET本地开发时常见的配置错误及解决方法? 2025-06-10
- ASP.NET自助建站系统的数据库备份与恢复操作指南 2025-06-10
- 个人网站服务器域名解析设置指南:从购买到绑定全流程 2025-06-10
- 个人网站搭建:如何挑选具有弹性扩展能力的服务器? 2025-06-10
- 个人服务器网站搭建:如何选择适合自己的建站程序或框架? 2025-06-10
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
-
2025-05-25 2
-
2025-05-27 20
-
2025-05-27 81
-
2025-06-04 58
-
2025-06-04 33



