iOS開(kāi)發(fā)隱藏鍵盤(pán)方法總結(jié)
下面為大家?guī)?lái)我整理總結(jié)的幾種隱藏鍵盤(pán)的方法。
一、隱藏自身軟鍵盤(pán)
當(dāng)對(duì)于有多個(gè)UITextField控件都想通過(guò)點(diǎn)擊“Return”來(lái)隱藏自身軟鍵盤(pán)的情況,這時(shí)的最好辦法是使用Did End on Exit事件。在點(diǎn)擊軟鍵盤(pán)右下角的“Return”按鈕后,會(huì)觸發(fā)該事件。
該事件有一個(gè)sender參數(shù)表示當(dāng)前文本框,這樣便可以編寫(xiě)一個(gè)通用的事件處理方法(.m文件)——
- - (IBAction)TextField_DidEndOnExit:(id)sender {
- // 隱藏鍵盤(pán).
- [sender resignFirstResponder];
- }
然后在.h文件中填寫(xiě)該方法的聲明——
- - (IBAction)TextField_DidEndOnExit:(id)sender;
回到storyboard,并按command+option+enter打開(kāi)輔助窗口,使輔助窗口顯示.h文件。 選中一個(gè)UITextField控件,點(diǎn)擊鼠標(biāo)右鍵彈出面板,鼠標(biāo)左鍵按住Did End on Exit事件旁邊的圓圈,然后拖曳到右側(cè).h文件的TextField_DidEndOnExit方法上,便會(huì)建立好事件連接。 隨后按照同樣的做法,將其他UITextField控件的Did End on Exit事件也連接到TextField_DidEndOnExit方法。
運(yùn)行一下,可發(fā)現(xiàn)每個(gè)文本框的軟鍵盤(pán)都可以通過(guò)點(diǎn)擊“Return”來(lái)隱藏了。
二、點(diǎn)擊Return自動(dòng)轉(zhuǎn)到下個(gè)文本框
當(dāng)頁(yè)面中有很多個(gè)文本框時(shí),如果每次都需要點(diǎn)文本框激活軟鍵盤(pán)、輸入后點(diǎn)擊Return隱藏軟鍵盤(pán)、再點(diǎn)擊下一個(gè)文本框……這樣操作起來(lái)太繁瑣了。 于是我們希望能夠?qū)崿F(xiàn)點(diǎn)擊Return時(shí)能夠自動(dòng)轉(zhuǎn)到下一個(gè)文本框。尤其是對(duì)于最后一個(gè)文本框,希望能夠在點(diǎn)擊Return時(shí)執(zhí)行下一步操作。
例如對(duì)于登錄頁(yè)面。它上面有 賬號(hào)文本框(nameTextField)、密碼文本框(passTextField)、登錄按鈕(loginButton)。
我們希望——點(diǎn)擊賬號(hào)文本框軟鍵盤(pán)的Return時(shí)跳轉(zhuǎn)到密碼文本框,點(diǎn)擊密碼文本框軟鍵盤(pán)的Return時(shí)執(zhí)行登錄。
因?yàn)檫@兩個(gè)文本框的功能不同,不能像上一節(jié)那樣寫(xiě)一個(gè)TextField_DidEndOnExit做統(tǒng)一處理,而應(yīng)該分別建立各自的事件處理方法。
回到storyboard,右擊賬號(hào)文本框(nameTextField)彈出面板,按住Did End on Exit事件旁邊的圓圈,然后拖曳到右側(cè).h文件的空白地方,此時(shí)會(huì)彈出一個(gè)對(duì)話框給方法命名。輸入名稱 (nameTextField_DidEndOnExit)后回車確定,便自動(dòng)生成了該事件方法。
隨后按照同樣的做法,為密碼文本框(passTextField)的Did End on Exit事件連接方法(passTextField_DidEndOnExit)。
來(lái)到.m文件,填寫(xiě)具體代碼——
- - (IBAction)nameTextField_DidEndOnExit:(id)sender {
- // 將焦點(diǎn)移至下一個(gè)文本框.
- [self.passTextField becomeFirstResponder];
- }
- - (IBAction)passTextField_DidEndOnExit:(id)sender {
- // 隱藏鍵盤(pán).
- [sender resignFirstResponder];
- // 觸發(fā)登陸按鈕的點(diǎn)擊事件.
- [self.loginButton sendActionsForControlEvents:UIControlEventTouchUpInside];
- }
對(duì)于賬號(hào)文本框轉(zhuǎn)密碼文本框,不需要隱藏軟鍵盤(pán),只需要調(diào)用becomeFirstResponder激活新的文本框就行了。
對(duì)于密碼文本框Return后執(zhí)行登錄。因?yàn)椴辉傩枰@示軟鍵盤(pán),所以還是得調(diào)用resignFirstResponder隱藏軟鍵盤(pán),然后觸發(fā)登錄按鈕(loginButton)的UIControlEventTouchUpInside事件進(jìn)行登錄。
運(yùn)行一下,可發(fā)現(xiàn)已經(jīng)達(dá)到我們希望的效果了。點(diǎn)擊賬號(hào)文本框軟鍵盤(pán)的Return時(shí)跳轉(zhuǎn)到密碼文本框,點(diǎn)擊密碼文本框軟鍵盤(pán)的Return時(shí)執(zhí)行登錄。
怎么都是“Return”,轉(zhuǎn)換文本框與執(zhí)行登錄明明是不同的功能?
于是將賬號(hào)文本框的Return Key屬性設(shè)為“Next”,將密碼文本框的Return Key屬性設(shè)為“Done”,使界面與功能一致。
三、輕觸背景隱藏軟鍵盤(pán)
只能通過(guò)Return關(guān)閉軟鍵盤(pán)太不靈活了,應(yīng)該提供輕觸背景隱藏軟鍵盤(pán)的功能。
在storyboard,點(diǎn)擊背景View,將它的Custom Class設(shè)置為UIControl,這樣才會(huì)出現(xiàn)Touch Down事件。
右擊背景View彈出面板,按住Touch Down事件旁邊的圓圈,然后拖曳到右側(cè).h文件的空白地方建立該事件的處理方法。
來(lái)到.m文件,填寫(xiě)具體代碼——
- - (IBAction)View_TouchDown:(id)sender {
- // 發(fā)送resignFirstResponder.
- [[UIApplication sharedApplication] sendAction:@selector(resignFirstResponder) to:nil from:nil forEvent:nil];
- }
把這些方法分享給大家希望能對(duì)讀者朋友們有所幫助。