一行代碼教你解決Scrollview和TextInput焦點獲取問題
前言
業(yè)務開發(fā)中搜索框和列表的組合頁面應該是比較常見的場景,那么有什么坑呢?
最近在開發(fā)過程就遇到了一個問題,輸入搜索關鍵詞查詢接口返回數據后,點擊列表項并返回上個頁面時,發(fā)現需要兩次點擊,納尼?頁面示意圖如下

通過日志以及邏輯分析發(fā)現兩個問題:
- 1.第一次點擊列表項無法觸發(fā)onPress點擊事件
- 2.第一次點擊其實是使輸入框失去焦點并隱藏鍵盤
知道問題在哪就有解決問題的方向了:點擊列表項使輸入框自動失去焦點,并觸發(fā)onPress點擊事件。
嘗試方案
- 1.通過點擊事件添加Keyboard.dismiss(),并使用輸入框ref調用blur()方法
- 2.通過使用Scrollview包裹整個頁面,添加keyboardShouldPersistTaps={'handled'}設置項(網上方案)
方案結果:
- 沒有作用
- 沒有效果,且上面的搜索框會一起滾動
最終方案
通過在技術群溝通,有位群友提出方案
scrollview 容器加 keyboardDismissMode="on-drag" 實踐后,并未解決此問題
最終通過嘗試在列表Flatlist中添加屬性keyboardShouldPersistTaps={'always'}成功解決
示例代碼如下:
// 自定義輸入框
<CustomizeSearchBar
value={searchText}
actionPress={onActionPress}
placeholder='請輸入昵稱/地址/姓名/手機號查詢' onSearchChange={onSearchChange}/>
<FlatList
keyboardShouldPersistTaps={'always'}
style={{flex: 1}}
data={addressList}
renderItem={renderItem}
ListEmptyComponent={<ListEmpty type={2} />}
keyExtractor={(item) => item.id}
/>
復制代碼附RN中文網對keyboardShouldPersistTaps的解釋說明:

最后
寫了Android和Flutter混合開發(fā)一年多,又開始寫RN了,就想一個圓一樣。
小伙伴們,你們現在是做RN,Flutter,原生,還是轉行了?
以上就是一行代碼教你解決Scrollview和TextInput焦點獲取問題的詳細內容,更多關于Scrollview TextInput焦點獲取的資料請關注腳本之家其它相關文章!
相關文章
詳解Android WebView的input上傳照片的兼容問題
本篇文章主要介紹了詳解Android WebView的input上傳照片的兼容問題,非常具有實用價值,需要的朋友可以參考下2017-08-08

