iOS 開(kāi)發(fā)之 - 關(guān)閉鍵盤(pán) 退出鍵盤(pán) 的5種方式
iOS 開(kāi)發(fā)之 - 關(guān)閉鍵盤(pán) 退出鍵盤(pán) 的5種方式
1、點(diǎn)擊編輯區(qū)以外的地方(UIView)
2、點(diǎn)擊編輯區(qū)域以外的地方(UIControl)
3、使用制作收起鍵盤(pán)的按鈕
4、使用判斷輸入字元
5、關(guān)于鍵盤(pán)遮蔽的問(wèn)題
1,點(diǎn)擊編輯區(qū)以外的地方(UIView)
這是一種很直覺(jué)的方法,當(dāng)不再需要使用虛擬鍵盤(pán)時(shí),只要點(diǎn)擊虛擬鍵盤(pán)和編輯區(qū)域外的地方,就可以將鍵盤(pán)收起,下面程式碼是在 UIView 中內(nèi)建的觸碰事件方法函式,您可以參考 Touch Panel / 觸碰螢?zāi)?/ 壓力感應(yīng)器的基本使用方式一文,找到更多關(guān)于觸碰事件的方法函式。
- (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event {
if (![myTextView isExclusiveTouch]) {
[myTextView resignFirstResponder];
}
}
如果要使用此方式請(qǐng)務(wù)必記得,你操作畫(huà)面的 Custom Class 一定要是 UIView 才行。
畫(huà)面的 Custom Class 為 UIView
2. 點(diǎn)擊編輯區(qū)域以外的地方(UIControl)
收起虛擬鍵盤(pán)的方式與前一種相同,但是如果你的觸碰事件里已經(jīng)且寫(xiě)滿了程式碼,那么就可以考慮使用,UIControl 的 Touch Up Inside 事件來(lái)收起鍵盤(pán),方法是將以下程式碼與 UIControl 的 Touch Up Inside 事件連結(jié)即可。
- (IBAction)dismissKeyboard:(id)sender {
[myTextView resignFirstResponder];
}
如果要使用此方式請(qǐng)務(wù)必記得,你操作畫(huà)面的 Custom Class 一定要是 UIControl 才行。
畫(huà)面的 Custom Class 為 UIControl
將收起鍵盤(pán)的方法與 UIControl 事件連結(jié)
3. 使用制作收起鍵盤(pán)的按鈕
當(dāng)沒(méi)有編輯區(qū)域以外的地方可供點(diǎn)擊來(lái)收起鍵盤(pán),自己制作一個(gè)按鈕來(lái)收起目前的虛擬鍵盤(pán),也是一個(gè)不錯(cuò)的方法,由于按鈕必須在虛擬鍵盤(pán)出現(xiàn)才能顯示于畫(huà)面上,因此必須借用 NSNotificationCenter 來(lái)幫助我們判斷目前鍵盤(pán)的狀態(tài)。
首先在 viewDidLoad: 事件中,向 NSNotificationCenter 進(jìn)行註冊(cè),告訴 NSNotificationCenter 我們的 doneButtonshow: 方法函式。
- (void)viewDidLoad {
[super viewDidLoad];
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector (doneButtonshow:) name: UIKeyboardDidShowNotification object:nil];
}
現(xiàn)在每當(dāng)虛擬鍵盤(pán)出現(xiàn)時(shí),就會(huì)自動(dòng)呼叫我們自定義的 doneButtonshow: 方法函式,接下來(lái)只要在該方法函式里定義按鈕出現(xiàn)的方法即可。
-(void) doneButtonshow: (NSNotification *)notification {
doneButton = [UIButton buttonWithType: UIButtonTypeRoundedRect];
doneButton.frame = CGRectMake(0, 228, 70, 35);
[doneButton setTitle:@"完成編輯" forState: UIControlStateNormal];
[doneButton addTarget: self action:@selector(hideKeyboard) forControlEvents: UIControlEventTouchUpInside];
[self.view addSubview:doneButton];
}
最后是實(shí)作按鈕按下去時(shí)的 hideKeyboard: 方法函式,務(wù)必記得要在函式中移除該按鈕。
-(void) hideKeyboard {
[doneButton removeFromSuperview];
[myTextView resignFirstResponder];
}
4. 使用判斷輸入字元
如果要使用輸入特定字元(例如 return 換行字元)來(lái)收起鍵盤(pán),必須先在類別內(nèi)的 @interface 區(qū)段採(cǎi)用 協(xié)定,您可以參考 Protocol 協(xié)定的使用方式一文,獲得更多關(guān)于協(xié)定的資訊。
在采用 協(xié)定之后,接著實(shí)作出協(xié)定內(nèi)的 textView:shouldChangeTextInRange:replacementText:方法函式,此方法函式會(huì)在字元輸入時(shí)觸發(fā),而回傳的 BOOL 值則代表該字元是否要作用,下列程式碼就是在此方法函式中,使用判斷輸入字元的方式來(lái)收起虛擬鍵盤(pán)(判斷字元為 return 換行字元)。
- (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text {
if ([text isEqualToString:@"\n"]) {
[myTextView resignFirstResponder];
return NO;
}
return YES;
}
最后別忘記在 viewDidLoad: 事件中,將 UITextView 的代理物件指向自己,這樣程式才能正確找到實(shí)作 協(xié)定方法函式的類別。
- (void)viewDidLoad {
[super viewDidLoad];
myTextView.delegate = self;
}
5. 關(guān)于鍵盤(pán)遮蔽的問(wèn)題
如果您在實(shí)作上有遭遇到鍵盤(pán)遮蔽編輯區(qū)域的問(wèn)題,可以參考使用 Animation 解決小鍵盤(pán)擋住 UITextField 的問(wèn)題一文,透過(guò) Core Graphic 的 Animation 功能,在鍵盤(pán)出現(xiàn)時(shí)同時(shí)移動(dòng)編輯區(qū)域來(lái)解決遮蔽的問(wèn)題。
以上就是對(duì)IOS關(guān)閉鍵盤(pán) 退出鍵盤(pán) 5種方式的資料整理,謝謝大家對(duì)本站的支持!
- 詳解IOS點(diǎn)擊空白處隱藏鍵盤(pán)的幾種方法介紹
- 總結(jié)IOS中隱藏軟鍵盤(pán)的三種方式
- 解決ios模擬器不能彈出鍵盤(pán)問(wèn)題的方法
- iOS應(yīng)用開(kāi)發(fā)中監(jiān)聽(tīng)鍵盤(pán)事件的代碼實(shí)例小結(jié)
- 總結(jié)IOS關(guān)閉鍵盤(pán)/退出鍵盤(pán)的五種方式
- 解決vue js IOS H5focus無(wú)法自動(dòng)彈出鍵盤(pán)的問(wèn)題
- IOS關(guān)閉鍵盤(pán)的方法
- iOS讓軟鍵盤(pán)消失的簡(jiǎn)單方法
- 代碼詳解ios鍵盤(pán)收起問(wèn)題
- iOS鍵盤(pán)如何添加隱藏鍵盤(pán)功能
相關(guān)文章
iOS的UI開(kāi)發(fā)中Button的基本編寫(xiě)方法講解
這篇文章主要介紹了iOS的UI開(kāi)發(fā)中Button的基本編寫(xiě)方法講解,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-11-11
配置iOS?16?屏幕旋轉(zhuǎn)適配實(shí)例詳解
這篇文章主要為大家介紹了配置iOS?16?屏幕旋轉(zhuǎn)適配實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
UIMenuController在Cell內(nèi)部無(wú)法顯示的解決辦法(iOS9.2)
這篇文章主要為大家詳細(xì)介紹了UIMenuController在Cell內(nèi)部無(wú)法顯示的解決辦法,感興趣的小伙伴們可以參考一下2016-08-08
iOS開(kāi)發(fā)總結(jié)之UILabel常用屬性介紹
下面小編就為大家分享一篇iOS開(kāi)發(fā)總結(jié)之UILabel常用屬性介紹,具有很的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
iOS開(kāi)發(fā)中使用屏幕旋轉(zhuǎn)功能的相關(guān)方法
這篇文章主要介紹了iOS開(kāi)發(fā)中使用屏幕旋轉(zhuǎn)功能的相關(guān)方法,包括Transform變化矩陣原理的講解,需要的朋友可以參考下2015-09-09

