关于UIAlertController的用法
2015-12-31 本文已影响1961人
4ba6804ff45f
关于UIAlertController的用法
简介
在新版本的Xcode中增加了UIAlertController而UIAlertView在调用时则会显示已经过期。本人在使用中经常会使用到Alert窗口,所以整理一下用法以方便自己使用。
基本语法
一、基础控件的添加(原UIAlertView)
- 创建一个UIAlertController对象:
UIAlertController *alertOne = [UIAlertController alertControllerWithTitle:@"I'm alertOne" message:@"I want to tell you something" preferredStyle:UIAlertControllerStyleAlert];
[self presentViewController:alertOne animated:YES completion:nil];
- 这一段代码初始化了一个最基本名字叫alertOne;Title为『I'm alertOne』;显示内容为『I want to tell you something』;而Style设为UIAlertControllerStyleAlert(最常见的弹出式alert。一共有两种,还有一种从下弹出式,稍后讲解)的UIAlertController对象。效果如下,因为没有添加AlertAction所以看起来很丑。
data:image/s3,"s3://crabby-images/15c85/15c8567f56dc262677b3b3055c42b4fc21ccb7e6" alt=""
- 让我们来为它添加一个『取消』按钮和一个『确定』按钮,让它看起来正常一些。
UIAlertAction *cancel = [UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil];
[alertOne addAction:cancel];
UIAlertAction *certain = [UIAlertAction actionWithTitle:@"确定" style:UIAlertActionStyleDefault handler:nil];
[alertOne addAction:certain];
- 初始化方法中Title对应着显示出来按钮的名称;style对于的是按钮的类型,有三种类型,这里用到了Cancel和Default,取消和默认的样式;还有一种是Destructive (销毁)样式,我们稍后添加。这样,我们就给他安上了两个按钮,就实现最基本也是最常见的alert样式。来看一下效果:
data:image/s3,"s3://crabby-images/0eaa3/0eaa31cac010b29a9091fca4ceb2530ae4981f4d" alt=""
- 接着我们继续在AlertController上插入一个textField控件,实现输入监听。
[alertOne addTextFieldWithConfigurationHandler:
^(UITextField * _Nonnull textField) {
// 监听
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(handleTextFieldTextDidChangeNotification:) name:UITextFieldTextDidChangeNotification object:textField];
// 定制键盘和输入框背景文字及clearButton
textField.placeholder = @"请输入";
textField.clearButtonMode = UITextFieldViewModeWhileEditing;
}];
- 这一段是在其自带的block代码块中利用NSNotificationCenter来实现值的传输。如果输入有变动的话就会传出变化的值。当然也可以根据需要写在按钮的方法block块中,以实现点击『取消』或『确定』按钮时实现相应的功能。然后我们继续完成handleTextFieldTextDidChangeNotification:方法:
- (void)handleTextFieldTextDidChangeNotification:(NSNotification *)notification
{
UITextField *textField = notification.object;
self.textLabel.text = textField.text;
}
data:image/s3,"s3://crabby-images/fdbbb/fdbbb39f5a55c495ef6d79b9261de9ccb8eb9bf8" alt=""
二、从下方弹出式UIAlertController(原UIActionSheet)
- 上边我们使用的是基于UIAlertControllerStyleAlert风格的,下边来尝试一下另一种风格UIAlertControllerStyleActionSheet的使用方法。
NSString *title = NSLocalizedString(@"AlertTwo", nil);
UIAlertController *alertTwo = [UIAlertController alertControllerWithTitle:title message:nil preferredStyle:UIAlertControllerStyleActionSheet];
data:image/s3,"s3://crabby-images/516e3/516e344ac827459fd086079df34ca264c53db6c6" alt=""
- 这是最原始的形态,还是一样的丑,而且一样无法返回,添加按钮方法同上,但是这次我们把一个换成Destructive风格来看一下效果。
UIAlertAction *cancel = [UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil];
[alertTwo addAction:cancel];
UIAlertAction *certain = [UIAlertAction actionWithTitle:@"清空" style:UIAlertActionStyleDestructive handler:
^(UIAlertAction * _Nonnull action) {
self.textLabel.text = nil;
}];
[alertTwo addAction:certain];
data:image/s3,"s3://crabby-images/9410e/9410e296ff1606b1d9ed9d4be71b1bc8dde80dc5" alt=""
- 再添加按钮以后,把alertTwo对象的Title设为nil,便可以把最上方的Title栏去掉,变成如下效果。
data:image/s3,"s3://crabby-images/b7620/b7620240ca364cb13e05fa0636633b693f8069f6" alt=""
-
这种风格的AlertController是不可以添加textField控件的。报错信息为『reason: 'Text fields can only be added to an alert controller of style UIAlertControllerStyleAlert'』,苹果官方很明确地表示了不可以。
-
UIAlertControllerStyleAlert说:『我就看看,不说话!』
data:image/s3,"s3://crabby-images/de887/de887c4eb9d75fbb1a833d55045ac119e0dbde12" alt=""
- UIAlertController用法比较简单,但是比较实用。如果想要实现更繁杂的功能或者效果还是需要自己去定制的。