前言
在ios 11發布之后,出現了一系列適配相關的問題,uiscrollview在pagingenabled=yes時滑動手勢不靈敏,uitableview的滑動刪除功能變動,uiimagepickerviewcontroller的取消按鈕點擊區域變小等,本文介紹其中一個uialertview問題,分享其發現、定位和解決。
正文
1、問題產生
問題的最初,是ios 11正式版發布后不久,測試的同學提了一個ios 11相關的bug,表現是:在直播間內發送聊天信息,如果被禁言,會彈出“被禁言”提示,鍵盤收回去,然后就彈不出來。
開發在接到這個bug的時候,先把問題抽象出來幾個要素:直播間內、鍵盤彈出、彈出提示、鍵盤收回、鍵盤無法彈出。
“彈出提示是用的uialertview的方式。在鍵盤出現時彈出uialertview的提示,鍵盤會收起,uialertview消失后,鍵盤會再次彈出,是一次正常的表現。”
2、問題復現
按照復現路徑做一次嘗試,發現bug可以復現,確定問題存在;
根據經驗,猜測問題可能出現在鍵盤和uialertview上,與“禁言”的業務無關。
在直播間內嘗試其他非“禁言”的場景,同樣是在鍵盤出現的時候,彈出uialertview的提示,也會造成后續鍵盤無法彈出的情況。
在嘗試完其他非直播間的主場景之后,發現問題可以描述為:
ios 11的機器只要彈出來一次uialertview,之后再通過becomefirstresponder無法呼起鍵盤;必須手動點擊輸入區域,觸發系統的鍵盤彈出行為,或者切入后臺再切回來,才能正常彈出來鍵盤。
部分頁面在點擊評論后,會添加一層透明maskview,并彈出鍵盤。點擊透明的maskview會調用resignfirstresponder,在鍵盤消失的notification中消除maskview。因為鍵盤無法彈出(也無法收到鍵盤消失的notification,但maskview還是正常添加),導致這部分頁面無法進行后續的交互。
3、問題評估
在復現問題后,需要對問題的嚴重性進行評估,確定bug修復的優先級。
從已知的表現來看,ios 11下的使用影響較大(uialertview的提示較多)。
用ios 11的機器下載外網版本進行測試,發現bug竟然無法復現!
雖然很詭異,但是問題的優先級可以降到更低,排入正常的bug解決列表中。
4、問題解析
外網版本是xcode8編譯的本,本地版本使用的xcode9 gm編譯的,難道是xcode 9編譯導致?
1、新建一個demo,只有輸入框和按鈕,模擬uialertview彈出,發現demo是正常的;
2、把app的工程設置復制到demo,把對輸入框的屬性設置同樣復制到demo,demo依舊正常;
3、把demo代碼復制到app,并把app的rootviewcontroller賦值為demo中的vc,依舊正常;
可以確定是app中某部分代碼導致的鍵盤無法彈出的。
經過二分注釋的方式,迅速(4、5次左右)定位到問題是app中的某個service類導致。
仔細排插service類的屬性,發現里面有一個屬性的是繼承uiwindow并且level比uiwindowlevelstatusbar高。
自此,根據所學和蘋果uikit的文檔,我們可以對問題進行一次回溯。
5、問題回溯
蘋果官網上響應鏈和uiwindow的說明,里面關于becomefirstresponder()的解釋是:asks uikit to make this object the first responder in its window.
對于uialertview的ios 11系統行為,猜測:
1、在uialertview彈出的時候,會搶占系統的keywindow,所以會出現鍵盤在uialertview的時候收回(因為keywindow改變);
2、在uialertview消失的時候,會遍歷所有window,找到其中z軸最高作為keywindow,所以會出現鍵盤在uialertview消失后彈出(keywindow變成原來的);
通過寫代碼調試app,確定了上面的猜測。
在ios 11,如果uialertview彈出時,存在windowlevel 大于 uiwindowlevelnormal 的uiwindow,就會觸發這個鍵盤無法彈出的bug。
6、問題修復
1、保證app中,沒有常駐的uiwindow;
2、修復鍵盤無法彈出時,maskview無法消除的bug;
3、uialertview在后續的版本替換掉;
總結
這次問題從產生、復現、定位、評估再到修復的時間,和寫這篇文章的時間差不多。
bug的解決流程各不相同,借此提醒自己對于bug的解決要有目的性和優先級。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:http://www.jianshu.com/p/523b4048df8f