IOS中輸入框被軟鍵盤遮擋的解決辦法

2021-06-19 13:04:19 字數 1359 閱讀 5966

做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...