iOS開(kāi)發(fā)之UIKeyboardTypeNumberPad數(shù)字鍵盤(pán)自定義按鍵
最近做一個(gè)搜索用戶的功能,這里使用了UISearchBar。由于搜索的方式只有手機(jī)號(hào)碼,所以這里的鍵盤(pán)要限制為數(shù)字輸入,可以這么做:
self.searchBar.keyboardType = UIKeyboardTypeNumberPad;如果使用的不是搜索框而是textField輸入框,可以設(shè)置textField的鍵盤(pán)屬性來(lái)展示 self.textField.keyboardType = UIKeyboardTypeNumberPad;監(jiān)聽(tīng)事件如下所示即可。
但是這里有個(gè)問(wèn)題,就是數(shù)字鍵盤(pán)上面沒(méi)有“搜索”按鈕,這樣子用戶在輸入完手機(jī)號(hào)碼后無(wú)法搜索。所以這個(gè)時(shí)候我們需要自己添加一個(gè)自定義的搜索按鈕,然后加到鍵盤(pán)上面。
解決思路如下所示:
1.自定義搜索button
2.監(jiān)聽(tīng)鍵盤(pán)出現(xiàn)的事件
3.遍歷搜索的Windows窗體,找到鍵盤(pán)的窗體,然后遍歷其子視圖,找到我們真正需要的鍵盤(pán)視圖
4.把我們自定義的按鈕加到上面找到的視圖里
這里要注意的一點(diǎn),隨著iOS SDK的不斷發(fā)展,keyboard的視圖名稱(chēng)也不斷在更新變化,當(dāng)你調(diào)試以下代碼無(wú)法得到期待的效果時(shí),請(qǐng)重新遍歷一次窗臺(tái),然后慢慢調(diào)試,找到真正需要的視圖名稱(chēng)。
解決代碼
1.自定義搜索按鈕
// 搜索按鈕 _searchButton = [UIButton buttonWithType:UIButtonTypeCustom]; _searchButton.frame = CGRectMake(0, 163, 106, 53); [_searchButton setTitle:@"搜索" forState:UIControlStateNormal]; [_searchButton setTitleColor:[UIColor blackColor] forState:UIControlStateNormal]; [_searchButton addTarget:self action:@selector(SearchButtonDidTouch:) forControlEvents:UIControlEventTouchUpInside];
2.監(jiān)聽(tīng)鍵盤(pán)出現(xiàn)的事件
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillShowOnDelay:) name:UIKeyboardWillShowNotification object:nil]; - (void)keyboardWillShowOnDelay:(NSNotification *)notification { [self performSelector:@selector(keyboardWillShow:) withObject:nil afterDelay:0]; }
這里面監(jiān)聽(tīng)通知后的執(zhí)行函數(shù)并非立馬執(zhí)行查找窗體的函數(shù),是因?yàn)樵趇OS4后,鍵盤(pán)添加到窗體的事件放到了下一個(gè)EventLoop,所以我們采用了延遲的方法。
3. 遍歷視圖,并添加按鈕
- (void)keyboardWillShow:(NSNotification *)notification { UIView *foundKeyboard = nil; UIWindow *keyboardWindow = nil; for (UIWindow *testWindow in [[UIApplication sharedApplication] windows]) { if (![[testWindow class] isEqual:[UIWindow class]]) { keyboardWindow = testWindow; break; } } if (!keyboardWindow) return; for (__strong UIView *possibleKeyboard in [keyboardWindow subviews]) { if ([[possibleKeyboard description] hasPrefix:@"<UIInputSetContainerView"]) { for (__strong UIView *possibleKeyboard_2 in possibleKeyboard.subviews) { if ([possibleKeyboard_2.description hasPrefix:@"<UIInputSetHostView"]) { foundKeyboard = possibleKeyboard_2; } } } } if (foundKeyboard) { if ([[foundKeyboard subviews] indexOfObject:_searchButton] == NSNotFound) { [foundKeyboard addSubview:_searchButton]; } else { [foundKeyboard bringSubviewToFront:_searchButton]; } } }
以上所述是小編給大家介紹的iOS開(kāi)發(fā)之UIKeyboardTypeNumberPad數(shù)字鍵盤(pán)自定義按鍵,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- 總結(jié)IOS關(guān)閉鍵盤(pán)/退出鍵盤(pán)的五種方式
- ionic在開(kāi)發(fā)ios系統(tǒng)微信時(shí)鍵盤(pán)擋住輸入框的解決方法(鍵盤(pán)彈出問(wèn)題)
- IOS開(kāi)發(fā)中鍵盤(pán)輸入屏幕上移的解決方法
- 總結(jié)IOS中隱藏軟鍵盤(pán)的三種方式
- iOS 鍵盤(pán)輸入限制(只能輸入字母,數(shù)字,禁止輸入特殊符號(hào))
- iOS表情鍵盤(pán)的簡(jiǎn)單實(shí)現(xiàn)代碼
- IOS關(guān)閉鍵盤(pán)的方法
- iOS中判斷Emoji表情問(wèn)題
- 關(guān)于iOS自帶九宮格拼音鍵盤(pán)和Emoji表情之間的一些坑
相關(guān)文章
IOS 開(kāi)發(fā)之swift中UIView的擴(kuò)展使用的實(shí)例
這篇文章主要介紹了IOS 開(kāi)發(fā)之swift中UIView的擴(kuò)展使用的實(shí)例的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下2017-09-09iOS中一行代碼實(shí)現(xiàn) UIView 鏤空效果
這篇文章主要介紹了一行代碼實(shí)現(xiàn) UIView 鏤空效果,這是一種實(shí)現(xiàn) UIView 鏤空效果的方案,可以快速實(shí)現(xiàn)任意形狀的鏤空、文字的鏤空、帶鏤空的毛玻璃效果等。需要的朋友可以參考下2018-11-11iOS8調(diào)用相機(jī)報(bào)警告Snapshotting a view的解決方法
這篇文章主要介紹了iOS8調(diào)用相機(jī)報(bào)警告Snapshotting a view……的解決方法 ,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11iOS實(shí)現(xiàn)毛玻璃效果(無(wú)需要第三方)
這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)毛玻璃效果,無(wú)需要第三方,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05IOS內(nèi)存泄漏檢查方法及重寫(xiě)MLeakFinder
這篇文章主要介紹了IOS內(nèi)存泄漏檢查方法及如何重寫(xiě)MLeakFinder,幫助ios開(kāi)發(fā)者維護(hù)自身程序,感興趣的朋友可以了解下2021-04-04關(guān)于iOS導(dǎo)航欄返回按鈕問(wèn)題的解決方法
這篇文章主要為大家詳細(xì)介紹了關(guān)于iOS導(dǎo)航欄返回按鈕問(wèn)題的解決方法,對(duì)iOS自定義backBarButtonItem的點(diǎn)擊事件進(jìn)行介紹,感興趣的小伙伴們可以參考一下2016-05-05