html5中文学习网

您的位置: 首页 > ios » 正文

IOS开发:提示框的正确实现方式_IOS开发

[ ] 已经帮助:人解决问题

 IOS开发:提示框的正确实现方式 三联f4eHTML5中文学习网 - HTML5先行者学习网

  在从iOS8到iOS9的升级过程中,弹出提示框的方式有了很大的改变,在Xcode7 ,iOS9.0的SDK中,已经明确提示不再推荐使用UIAlertView,而只能使用UIAlertController,我们通过代码来演示一下。f4eHTML5中文学习网 - HTML5先行者学习网

  我通过点击一个按钮,然后弹出提示框,代码示例如下:f4eHTML5中文学习网 - HTML5先行者学习网

  [objc] view plaincopyprint?f4eHTML5中文学习网 - HTML5先行者学习网

  #import "ViewController.h"f4eHTML5中文学习网 - HTML5先行者学习网

  @interface ViewController ()f4eHTML5中文学习网 - HTML5先行者学习网

  @property(strong,nonatomic) UIButton *button;f4eHTML5中文学习网 - HTML5先行者学习网

  @endf4eHTML5中文学习网 - HTML5先行者学习网

  @implementation ViewControllerf4eHTML5中文学习网 - HTML5先行者学习网

  - (void)viewDidLoad {f4eHTML5中文学习网 - HTML5先行者学习网

  [super viewDidLoad];f4eHTML5中文学习网 - HTML5先行者学习网

  self.button = [[UIButton alloc] initWithFrame:CGRectMake(0, 100, [[UIScreen mainScreen] bounds].size.width, 20)];f4eHTML5中文学习网 - HTML5先行者学习网

  [self.button setTitle:@"跳转" forState:UIControlStateNormal];f4eHTML5中文学习网 - HTML5先行者学习网

  [self.button setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];f4eHTML5中文学习网 - HTML5先行者学习网

  [self.view addSubview:self.button];f4eHTML5中文学习网 - HTML5先行者学习网

  [self.button addTarget:self action:@selector(clickMe:) forControlEvents:UIControlEventTouchUpInside];f4eHTML5中文学习网 - HTML5先行者学习网

  }f4eHTML5中文学习网 - HTML5先行者学习网

  -(void)clickMe:(id)sender{f4eHTML5中文学习网 - HTML5先行者学习网

  UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"提示" message:@"按钮被点击了" delegate:self cancelButtonTitle:@"确定" otherButtonTitles:nil, nil nil];f4eHTML5中文学习网 - HTML5先行者学习网

  [alert show];f4eHTML5中文学习网 - HTML5先行者学习网

  }f4eHTML5中文学习网 - HTML5先行者学习网

  @endf4eHTML5中文学习网 - HTML5先行者学习网

  编写上述代码时,会有下列的警告提示:f4eHTML5中文学习网 - HTML5先行者学习网

  “‘UIAlertView’ is deprecated:first deprecated in iOS 9.0 - UIAlertView is deprecated. Use UIAlertController with a preferredStyle of UIAlertControllerStyleAlert instead”.f4eHTML5中文学习网 - HTML5先行者学习网

  说明UIAlertView首先在iOS9中被弃用(不推荐)使用。让我们去用UIAlertController。但是运行程序,发现代码还是可以成功运行,不会出现crash。f4eHTML5中文学习网 - HTML5先行者学习网

  但是在实际的工程开发中,我们有这样一个“潜规则”:要把每一个警告(warning)当做错误(error)。所以为了顺应苹果的潮流,我们来解决这个warning,使用UIAlertController来解决这个问题。代码如下:f4eHTML5中文学习网 - HTML5先行者学习网

  [objc] view plaincopyprint?f4eHTML5中文学习网 - HTML5先行者学习网

  #import "ViewController.h"f4eHTML5中文学习网 - HTML5先行者学习网

  @interface ViewController ()f4eHTML5中文学习网 - HTML5先行者学习网

  @property(strong,nonatomic) UIButton *button;f4eHTML5中文学习网 - HTML5先行者学习网

  @endf4eHTML5中文学习网 - HTML5先行者学习网

  @implementation ViewControllerf4eHTML5中文学习网 - HTML5先行者学习网

  - (void)viewDidLoad {f4eHTML5中文学习网 - HTML5先行者学习网

  [super viewDidLoad];f4eHTML5中文学习网 - HTML5先行者学习网

  self.button = [[UIButton alloc] initWithFrame:CGRectMake(0, 100, [[UIScreen mainScreen] bounds].size.width, 20)];f4eHTML5中文学习网 - HTML5先行者学习网

  [self.button setTitle:@"跳转" forState:UIControlStateNormal];f4eHTML5中文学习网 - HTML5先行者学习网

  [self.button setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];f4eHTML5中文学习网 - HTML5先行者学习网

  [self.view addSubview:self.button];f4eHTML5中文学习网 - HTML5先行者学习网

  [self.button addTarget:self action:@selector(clickMe:) forControlEvents:UIControlEventTouchUpInside];f4eHTML5中文学习网 - HTML5先行者学习网

  }f4eHTML5中文学习网 - HTML5先行者学习网

  -(void)clickMe:(id)sender{f4eHTML5中文学习网 - HTML5先行者学习网

  //初始化提示框;f4eHTML5中文学习网 - HTML5先行者学习网

  UIAlertController *alert = [UIAlertController alertControllerWithTitle:@"提示" message:@"按钮被点击了" preferredStyle: UIAlertControllerStyleAlert];f4eHTML5中文学习网 - HTML5先行者学习网

  [alert addAction:[UIAlertAction actionWithTitle:@"确定" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {f4eHTML5中文学习网 - HTML5先行者学习网

  //点击按钮的响应事件;f4eHTML5中文学习网 - HTML5先行者学习网

  }]];f4eHTML5中文学习网 - HTML5先行者学习网

  //弹出提示框;f4eHTML5中文学习网 - HTML5先行者学习网

  [self presentViewController:alert animated:true completion:nil];f4eHTML5中文学习网 - HTML5先行者学习网

  }f4eHTML5中文学习网 - HTML5先行者学习网

  @endf4eHTML5中文学习网 - HTML5先行者学习网

  这样,代码就不会有警告了。f4eHTML5中文学习网 - HTML5先行者学习网

  程序运行后的效果同上。 其中preferredStyle这个参数还有另一个选择:UIAlertControllerStyleActionSheet。选择这个枚举类型后,实现效果如下:f4eHTML5中文学习网 - HTML5先行者学习网

  发现这个提示框是从底部弹出的。是不是很简单呢?通过查看代码还可以发现,在提示框中的按钮响应不再需要delegate委托来实现了。直接使用addAction就可以在一个block中实现按钮点击,非常方便。f4eHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助