做ios開發時,難免會遇到輸入框被鍵盤遮掩的問題。上網上搜尋了很多相關的解決方案,看了很多,但是由衷的覺得太麻煩了。
有的解決方案是將檢視上的所有的東西都新增到乙個滾動檢視物件( uiscrollview )中,
然後滾動檢視實現輸入框不被軟鍵盤覆蓋,個人覺得此方案好是好,但是太過麻煩。
有的解決方案是通過乙個通知 uikeyboarddidshownotification
去實現的,需要用到事件監聽,而且需要自己定義並實現「將要開始編輯」與「結束編輯」這兩個監聽事件中的方法。本人也覺得很麻煩。
參考了很多方法,都不是太理想。自己研究了一下,既然軟鍵盤(keyboard)出現與否是跟輸入框(uitextfield)緊密關聯的。所以自己找到乙個解決方案,沒有上述兩種方案那麼麻煩,只需實現**uitextfielddelegate中的三個方法即可。
實現方法:
1)將輸入框的**設定為self
(在lb檔案中將輸入框的delegate設定為file』s owner 。或者使用**textfield.delegate = self;
2)將輸入框所對應的viewcontroller.h設定實現了uitextfielddelegate協議
在viewcontroller.m檔案中實現uitextfielddelegate的三個方法即可:
[cpp]view plain
copy
//開始編輯輸入框的時候,軟鍵盤出現,執行此事件
-(void
)textfielddidbeginediting:(uitextfield *)textfield
//當使用者按下return鍵或者按回車鍵,keyboard消失
-(bool
)textfieldshouldreturn:(uitextfield *)textfield
//輸入框編輯完成以後,將檢視恢復到原始狀態
-(void
)textfielddidendediting:(uitextfield *)textfield
方法很簡單吧?請注意一定
不要忘記設定輸入框的**delegate
哦實現效果如下圖所示:
Android輸入框被鍵盤遮擋
解決方案 在我們的linearlayout布局外新增scrollview 示例 由原來的 view plain print?xmlversion 1.0 encoding utf 8 linearlayout xmlns android android layout width fill paren...
iOS解決鍵盤遮擋輸入框問題
一 彈出鍵盤時,將整個檢視上移 監聽鍵盤事件 監聽鍵盤 1 鍵盤彈出時 nsnotificationcenter defaultcenter addobserver self selector selector keyboardwillshow name uikeyboardwillshownoti...
手機瀏覽器呼出軟鍵盤遮擋住輸入框問題。
在手機瀏覽器中如果我們給body設定了高度,然後我們通過input輸入框呼出軟鍵盤,如果輸入框在頁面下方,內容會被軟鍵盤遮擋住,我們只有滑動滾動條才能看到輸入框,這樣會很麻煩,也不利於使用者體驗。我們可以通過scrollintoviewifneeded 方法來解決問題。element.scrolli...