UIAlertController

從ios8之后,系統(tǒng)的彈框 UIAlertView 與 UIActionSheet 兩個并在一了起, 使用了一個新的控制器叫 UIAlertController


UIAlertController的基本使用

1.創(chuàng)建UIAlertController

Title:顯示的標(biāo)題
message:標(biāo)題底部顯示的描述信息
preferredStyle:彈框的樣式
樣式分為兩種:
UIAlertControllerStyleActionSheet:( 底部)
UIAlertControllerStyleAlert(中間)

兩種樣式分別顯示如下:

第一步:創(chuàng)建控制器
UIAlertController *alertController = [UIAlertController alertControllerWithTitle:@"確定要退出嘛?" message:@“顯示的信息" preferredStyle:UIAlertControllerStyleActionSheet];

第二步:創(chuàng)建按鈕
彈框當(dāng)中的每一個按鈕分別對應(yīng)一個 UIAlertAction

UIAlertAction創(chuàng)建方式如下:
actionWithTitle:按鈕要顯示的文字
style:按鈕要顯示的樣式
     樣式分為三種:
      UIAlertActionStyleDefault:默認樣式,默認按鈕顏色為藍色
      UIAlertActionStyleCancel:設(shè)置按鈕為取消.點擊取消是,會動退出彈框.
                               注意:取消樣式只能設(shè)置一個,如果有多個取消樣式,則會發(fā)生錯誤.
      UIAlertActionStyleDestructive:危險操作按鈕,按鈕顏色顯示為紅公
     handler:點擊按鈕時調(diào)用Block內(nèi)部代碼.

UIAlertAction *action = [UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:^(UIAlertAction * _Nonnull action) {
       NSLog(@"點擊了取消");
}];

UIAlertAction *action1 = [UIAlertAction actionWithTitle:@"確定" style:UIAlertActionStyleDestructive handler:^(UIAlertAction * _Nonnull action) {
       NSLog(@"點擊了取消");
       [self.navigationController popViewControllerAnimated:YES];
}];

第三步:添加按鈕
把創(chuàng)建的UIAlertAction添加到控制器當(dāng)中.
[alertController addAction:action];
[alertController addAction:action1];

除了添加按鈕之外,還可以添加文本框,
添加文本框的前提是UIAlertController的樣式必須得要是UIAlertControllerStyleAlert樣式.否則會直接報錯
添加文本框方法為:
[alertController addTextFieldWithConfigurationHandler:^(UITextField * _Nonnull textField) {
    textField.placeholder = @“文本框點位文字";
}];

運行效果為:

通過控制器的textFields屬性獲取添加的文本框.注意textFields它是一個數(shù)組.
UITextField *textF =  alertController.textFields.lastObject;

第四步:顯示彈框.(相當(dāng)于show操作)
[self presentViewController:alertController animated:YES completion:nil];

UIAertController放置可以輸入的textField

//點擊某一cell 就出現(xiàn)警示框
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath{
    
    //MARK: - 點擊某一行彈框
    UIAlertController * alertVc = [UIAlertController alertControllerWithTitle:@"編輯" message:@"修改個人信息" preferredStyle:UIAlertControllerStyleAlert];
    
    
    //MARK: -  只有UIAlertControllerStyleAlert 這種模式可以添加文本框
    if (alertVc.preferredStyle == UIAlertControllerStyleAlert) {
        
        //添加輸入框
        [alertVc addTextFieldWithConfigurationHandler:^(UITextField * _Nonnull textField) {
            NSLog(@"%@---->>",textField);
            self.alertTextFileContent = textField.text;
            

//            //監(jiān)聽文本框的改變
            [textField addTarget:self action:@selector(valueChange:) forControlEvents:UIControlEventEditingChanged];
//
//            [[NSNotificationCenter defaultCenter] addObserver:self
//                                                     selector:@selector(textFieldDidChangeValue:)
//                                                         name:UITextFieldTextDidChangeNotification
//                                                       object:textField];
        }];
}
     //MARK: - 添加確定和取消
    UIAlertAction * sure = [UIAlertAction actionWithTitle:@"確定" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {
        
        

        if (indexPath.row == 0) {
            
        UITableViewCell *cell = [tableView cellForRowAtIndexPath:indexPath];
        cell.detailTextLabel.text = self.alertTextFileContent;

        }
        //刷新數(shù)據(jù) ,重新調(diào)用數(shù)據(jù)源的代理方法
//        [self.tv_info reloadData];
        
        //        NSIndexPath * path = [NSIndexPath indexPathForRow:indexPath.row inSection:0];
        //
        //        [self.tv_info reloadRowsAtIndexPaths:@[path] withRowAnimation:UITableViewRowAnimationLeft];
        
    }];
    UIAlertAction * cancel = [UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {
        
    }];
    
    //MARK: - 顯示警示框
    [alertVc addAction:sure];
    [alertVc addAction:cancel];
    [self presentViewController:alertVc animated:YES completion:^{
        
    }];
    
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市鸽捻,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖璃饱,帶你破解...
    沈念sama閱讀 211,639評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件徒爹,死亡現(xiàn)場離奇詭異巍实,居然都是意外死亡腾啥,警方通過查閱死者的電腦和手機东涡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評論 3 385
  • 文/潘曉璐 我一進店門冯吓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人软啼,你說我怎么就攤上這事桑谍⊙幽” “怎么了祸挪?”我有些...
    開封第一講書人閱讀 157,221評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長贞间。 經(jīng)常有香客問我贿条,道長,這世上最難降的妖魔是什么增热? 我笑而不...
    開封第一講書人閱讀 56,474評論 1 283
  • 正文 為了忘掉前任整以,我火速辦了婚禮,結(jié)果婚禮上峻仇,老公的妹妹穿的比我還像新娘公黑。我一直安慰自己,他們只是感情好摄咆,可當(dāng)我...
    茶點故事閱讀 65,570評論 6 386
  • 文/花漫 我一把揭開白布凡蚜。 她就那樣靜靜地躺著,像睡著了一般吭从。 火紅的嫁衣襯著肌膚如雪朝蜘。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,816評論 1 290
  • 那天涩金,我揣著相機與錄音谱醇,去河邊找鬼。 笑死步做,一個胖子當(dāng)著我的面吹牛副渴,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播全度,決...
    沈念sama閱讀 38,957評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼佳晶,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了讼载?” 一聲冷哼從身側(cè)響起轿秧,我...
    開封第一講書人閱讀 37,718評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎咨堤,沒想到半個月后菇篡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,176評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡一喘,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,511評論 2 327
  • 正文 我和宋清朗相戀三年驱还,在試婚紗的時候發(fā)現(xiàn)自己被綠了嗜暴。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,646評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡议蟆,死狀恐怖闷沥,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情咐容,我是刑警寧澤舆逃,帶...
    沈念sama閱讀 34,322評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站戳粒,受9級特大地震影響路狮,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蔚约,卻給世界環(huán)境...
    茶點故事閱讀 39,934評論 3 313
  • 文/蒙蒙 一奄妨、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧苹祟,春花似錦砸抛、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至团赏,卻和暖如春箕般,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背舔清。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評論 1 266
  • 我被黑心中介騙來泰國打工丝里, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人体谒。 一個月前我還...
    沈念sama閱讀 46,358評論 2 360
  • 正文 我出身青樓杯聚,卻偏偏與公主長得像,于是被迫代替她去往敵國和親抒痒。 傳聞我的和親對象是個殘疾皇子幌绍,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,514評論 2 348

推薦閱讀更多精彩內(nèi)容