iOS中UIAlertController设置自定义标题与内容的方法-创新互联-成都创新互联网站建设

关于创新互联

多方位宣传企业产品与服务 突出企业形象

公司简介 公司的服务 荣誉资质 新闻动态 联系我们

iOS中UIAlertController设置自定义标题与内容的方法-创新互联

前言

创新互联专注于企业全网营销推广、网站重做改版、临汾网站定制设计、自适应品牌网站建设、H5网站设计电子商务商城网站建设、集团公司官网建设、成都外贸网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为临汾等各大城市提供网站开发制作服务。

相信大家都知道,UIAlertController的标题和内容都是黑色的(对UIAlertController不了解的朋友可以参考这篇文章),但是在很多场景下都需要修改他们的颜色,比如在输入错误时把提示信息变为红色,或者自定义标题的颜色,可是在公开的API接口中好像并没有对应的方法,那么我们应该怎么做呢?下面话不多说了,来一起看看详细的介绍:

第三方控件

第一种方法当然就是使用第三方的Alert控件了,现在Github上有着众多的Alert控件(如SCLAlertView等),相信有很多都可以满足大家的需求,只要使用Cocoapods添加添加第三方库就可以了。

KVC方法

但是也有一些人,不愿意去使用第三方库,而是想要使用系统的UIAlertController,这样当然也是可以的。苹果公司并没有完全的封死对UIAlertController的定制,而是修改为了使用KVC的方法进行定制。如果要自定义标题和内容,可以通过NSAttributedString把字体和颜色设置好,然后在通过KVC的方法进行设置,就可以了。

下面是一个示例代码和对应的截图:

- (void)testAlert {
 UIAlertController *alert = [UIAlertController alertControllerWithTitle:nil message:nil preferredStyle:UIAlertControllerStyleAlert];
 [alert addAction:[UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil]];
 NSDictionary *titleAttr = @{
  NSFontAttributeName:[UIFont boldSystemFontOfSize:20],
  NSForegroundColorAttributeName:[UIColor greenColor]
  };
 NSAttributedString *attributedTitle = [[NSAttributedString alloc] initWithString:@"测试有颜色标题" attributes:titleAttr];
 [alert setValue:attributedTitle forKey:@"attributedTitle"];

 NSDictionary *messageAttr = @{
  NSFontAttributeName:[UIFont systemFontOfSize:12],
  NSForegroundColorAttributeName:[UIColor redColor]
  };
 NSAttributedString *attributedMessage = [[NSAttributedString alloc] initWithString:@"测试有颜色文本" attributes:messageAttr];
 [alert setValue:attributedMessage forKey:@"attributedMessage"];
 [self presentViewController:alert animated:YES completion:nil];
}

另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前名称:iOS中UIAlertController设置自定义标题与内容的方法-创新互联
当前网址:http://kswsj.cn/article/doedgh.html

其他资讯