比較閒,整理了以前用過的一個第三方庫——鍵盤處理神器
IQKeyboardManager
。git
日常在開發中,用到輸入框的地方不勝其數,當輸入框位於屏幕底部時,彈起的鍵盤極可能覆蓋輸入框,致使用戶看不到輸入結果,體驗較差......
IQKeyboardManager
能夠很簡單快捷的解決鍵盤遮蓋輸入框的問題,接下來就一塊兒來學習一下吧。github
先簡單認識下 IQKeyboardManager
GitHub 地址:GitHub 地址app
官方示意效果圖以下:ide
再貼一下本身作的簡單效果圖☺️
先說下個人 Xcode 版本是:Version 8.1 (8B62),簡單起見直接在 Main.storyboard 中拖入 7 個UITextField, 每一個 UITextField 都設有佔位文字。工具
IQKeyboardManager 的 GitHub地址:IQKeyboardManager 的 GitHub 地址學習
#import <IQKeyboardManager/IQKeyboardManager.h>
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { IQKeyboardManager *keyboardManager = [IQKeyboardManager sharedManager]; // 獲取類庫的單例變量 keyboardManager.enable = YES; // 控制整個功能是否啓用 keyboardManager.shouldResignOnTouchOutside = YES; // 控制點擊背景是否收起鍵盤 keyboardManager.shouldToolbarUsesTextFieldTintColor = YES; // 控制鍵盤上的工具條文字顏色是否用戶自定義 keyboardManager.toolbarManageBehaviour = IQAutoToolbarBySubviews; // 有多個輸入框時,能夠經過點擊Toolbar 上的「前一個」「後一個」按鈕來實現移動到不一樣的輸入框 keyboardManager.enableAutoToolbar = YES; // 控制是否顯示鍵盤上的工具條 keyboardManager.shouldShowTextFieldPlaceholder = YES; // 是否顯示佔位文字 keyboardManager.placeholderFont = [UIFont boldSystemFontOfSize:17]; // 設置佔位文字的字體 keyboardManager.keyboardDistanceFromTextField = 10.0f; // 輸入框距離鍵盤的距離 return YES; }
- (void)viewWillAppear:(BOOL)animated { [super viewWillAppear:animated]; [IQKeyboardManager sharedManager].enable = NO; } - (void)viewWillDisappear:(BOOL)animated { [super viewWillDisappear:animated]; [IQKeyboardManager sharedManager].enable = YES; }
sharedManager
:獲取類庫的單例變量enable
:項目使用不使用 IQKeyboardManager 這個類庫,固然,某些頁面能夠根據須要單獨設置shouldResignOnTouchOutside
:點擊背景頁面時是否收起鍵盤shouldToolbarUsesTextFieldTintColor
:控制鍵盤上的工具條文字顏色是否用戶自定義,默認爲 NOtoolbarManageBehaviour
:有多個輸入框時,能夠經過點擊Toolbar 上的「前一個」 「後一個」按鈕來實現移動到不一樣的輸入框enableAutoToolbar
:是否顯示鍵盤上的工具條shouldShowTextFieldPlaceholder
:是否顯示佔位文字(若是輸入框有佔位文字,那麼在 Toolbar 中默認會顯示出來)placeholderFont
:佔位文字的字體大小keyboardDistanceFromTextField
:輸入框距離鍵盤的距離