UIAlertController 和 UIAlertAction 用法:
1. 最简单的提醒视图:
这里我们实现一个最简单的提醒视图,包含1个标题,1行信息,1个按键,按下按键后,什么都不发生:
- - (IBAction)doAlert:(id)sender {
- // 准备初始化配置参数
- NSString *title = @"Alert Button Selected";
- NSString *message = @"I need your attention NOW!";
- NSString *okButtonTitle = @"OK";
- // 初始化
- UIAlertController *alertDialog = [UIAlertController alertControllerWithTitle:title message:message preferredStyle:UIAlertControllerStyleAlert];
- // 创建操作
- UIAlertAction *okAction = [UIAlertAction actionWithTitle:okButtonTitle style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) {
- // 操作具体内容
- // Nothing to do.
- }];
- // 添加操作
- [alertDialog addAction:okAction];
- // 呈现警告视图
- [self presentViewController:alertDialog animated:YES completion:nil];
- }
进入程序后,点击“Alert Me!”按钮可触发这个提醒框,如图所示:
2. 多个按键的提醒视图
这里我们实现一个最简单的提醒视图,包含1个标题,1行信息,3个按键,按下按键后,标签显示按下的按键名称:
- - (IBAction)doMultiButtonAlert:(id)sender {
- // 准备初始化配置参数
- NSString *title = @"Alert Button Selected";
- NSString *message = @"I need your attention NOW!";
- NSString *okButtonTitle = @"OK";
- NSString *neverButtonTitle = @"Never";
- NSString *laterButtonTitle = @"Maybe Later";
- // 初始化
- UIAlertController *alertDialog = [UIAlertController alertControllerWithTitle:title message:message preferredStyle:UIAlertControllerStyleAlert];
- // 分别3个创建操作
- UIAlertAction *laterAction = [UIAlertAction actionWithTitle:laterButtonTitle style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) {
- // 普通按键
- self.userOutput.text = @"Clicked 'Maybe Later'";
- }];
- UIAlertAction *neverAction = [UIAlertAction actionWithTitle:neverButtonTitle style:UIAlertActionStyleDestructive handler:^(UIAlertAction *action) {
- // 红色按键
- self.userOutput.text = @"Clicked 'Never'";
- }];
- UIAlertAction *okAction = [UIAlertAction actionWithTitle:okButtonTitle style:UIAlertActionStyleCancel handler:^(UIAlertAction *action) {
- // 取消按键
- self.userOutput.text = @"Clicked 'OK'";
- }];
- // 添加操作(顺序就是呈现的上下顺序)
- [alertDialog addAction:laterAction];
- [alertDialog addAction:neverAction];
- [alertDialog addAction:okAction];
- // 呈现警告视图
- [self presentViewController:alertDialog animated:YES completion:nil];
- }
3个按键分别代表了3种不同类型的按键,分别是默认按键(普通)、销毁按键(红色)和取消按键(粗体)。从代码看其实就是在上一个的基础上加了3个 UIAlertAction 而已,然后分别设置不同的 style,效果如下:
3. 带输入框的提醒视图
如何添加输入框呢?新的 iOS 8 提供了相应的接口,使增加输入框就像增加按键方法一样简单。这里还是在第1个方法的基础上改动。
- - (IBAction)doAlertInput:(id)sender {
- // 准备初始化配置参数
- NSString *title = @"Email Address";
- NSString *message = @"Please enter your your email address:";
- NSString *okButtonTitle = @"OK";
- // 初始化
- UIAlertController *alertDialog = [UIAlertController alertControllerWithTitle:title message:message preferredStyle:UIAlertControllerStyleAlert];
- // 创建文本框
- [alertDialog addTextFieldWithConfigurationHandler:^(UITextField *textField){
- textField.placeholder = @"Your Email";
- textField.secureTextEntry = NO;
- }];
- // 创建操作
- UIAlertAction *okAction = [UIAlertAction actionWithTitle:okButtonTitle style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) {
- // 读取文本框的值显示出来
- UITextField *userEmail = alertDialog.textFields.firstObject;
- self.userOutput.text = userEmail.text;
- }];
- // 添加操作(顺序就是呈现的上下顺序)
- [alertDialog addAction:okAction];
- // 呈现警告视图
- [self presentViewController:alertDialog animated:YES completion:nil];
- }
在创建操作前先创建文本框,以便后面的按键可以操作文本框内容。创建文本框也只是用了一个简单的方法而已,想创建更多文本框就再使用多次这个方法即可,程序效果如下:
4. 提醒图表
与第2个和第3个方法相比,创建提醒图表简直易如反掌。因为和第1个方法相比,只需要改动一个参数就可以,即把创建UIAlertController实例的参数 UIAlertControllerStyleAlert 改为 UIAlertControllerStyleActionSheet ,别的都不用变。
- - (IBAction)doActionSheet:(id)sender {
- // 准备初始化配置参数
- NSString *title = @"Alert Button Selected";
- NSString *message = @"I need your attention NOW!";
- NSString *okButtonTitle = @"OK";
- NSString *neverButtonTitle = @"Never";
- NSString *laterButtonTitle = @"Maybe Later";
- // 初始化
- UIAlertController *alertDialog = [UIAlertController alertControllerWithTitle:title message:message preferredStyle:UIAlertControllerStyleActionSheet];
- // 分别3个创建操作
- UIAlertAction *laterAction = [UIAlertAction actionWithTitle:laterButtonTitle style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) {
- // 普通按键
- self.userOutput.text = @"Clicked 'Maybe Later'";
- }];
- UIAlertAction *neverAction = [UIAlertAction actionWithTitle:neverButtonTitle style:UIAlertActionStyleDestructive handler:^(UIAlertAction *action) {
- // 红色按键
- self.userOutput.text = @"Clicked 'Never'";
- }];
- UIAlertAction *okAction = [UIAlertAction actionWithTitle:okButtonTitle style:UIAlertActionStyleCancel handler:^(UIAlertAction *action) {
- // 取消按键
- self.userOutput.text = @"Clicked 'OK'";
- }];
- // 添加操作(顺序就是呈现的上下顺序)
- [alertDialog addAction:laterAction];
- [alertDialog addAction:neverAction];
- [alertDialog addAction:okAction];
- // 呈现警告视图
- [self presentViewController:alertDialog animated:YES completion:nil];
- }
效果如图: