最近用自己的 APP 打字的時候經常發(fā)現(xiàn),拖動選字欄的時候,鍵盤自動回收了,搜了好久都沒發(fā)現(xiàn)大家有這個問題,首先想到可以滑動的應該都是UIScrollView的子類,難道是UIScrollView添加分類或者Method Swizzling影響到了鍵盤?
然后我開始逐行查看分類的代碼,發(fā)現(xiàn)沒有地方影響。
隔了一天,我從另一個方向開始查找,能產生拖動回收的應該是scrollView.keyboardDismissMode = .onDrag, 所以我全局搜了一次,發(fā)現(xiàn)有這么一段代碼
private func setupAppearance() {
// UIScrollView
let scrollView = UIScrollView.appearance()
scrollView.keyboardDismissMode = .onDrag
scrollView.backgroundColor = .clear
}
突然好像明白了,使用 appearance 設置了鍵盤中的 scrollView.keyboardDismissMode = .onDrag,那么現(xiàn)在只要找到鍵盤所有UIScrollView 的子類并把他們的拖動回收鍵盤關掉就好了,于是先看了鍵盤的層級

鍵盤.jpg
發(fā)現(xiàn)選字的地方是一個collectionView,于是找到了它的父視圖,并添加了以下的代碼
private func setupAppearance() {
// UIScrollView
let scrollView = UIScrollView.appearance()
scrollView.keyboardDismissMode = .onDrag
scrollView.backgroundColor = .clear
if let type = NSClassFromString("UIKeyboardCandidateBar") as? UIAppearanceContainer.Type {
let keyboardCandidateBar = UIScrollView.appearance(whenContainedInInstancesOf: [type])
keyboardCandidateBar.keyboardDismissMode = .none
}
}
試了以下,沒想到成了。
雖然投機取巧的改了這個問題,但問題反思后發(fā)現(xiàn)盡量不要用 appearance,除非是項目特別統(tǒng)一的地方,但也可以通過繼承來實現(xiàn)控件標準化,而且通過這種方式修改默認值,很難發(fā)現(xiàn),后期也很容易忘記,很難維護。