一行代碼教你解決Scrollview和TextInput焦點(diǎn)獲取問題
前言
業(yè)務(wù)開發(fā)中搜索框和列表的組合頁面應(yīng)該是比較常見的場(chǎng)景,那么有什么坑呢?
最近在開發(fā)過程就遇到了一個(gè)問題,輸入搜索關(guān)鍵詞查詢接口返回?cái)?shù)據(jù)后,點(diǎn)擊列表項(xiàng)并返回上個(gè)頁面時(shí),發(fā)現(xiàn)需要兩次點(diǎn)擊,納尼?頁面示意圖如下
通過日志以及邏輯分析發(fā)現(xiàn)兩個(gè)問題:
- 1.第一次點(diǎn)擊列表項(xiàng)無法觸發(fā)onPress點(diǎn)擊事件
- 2.第一次點(diǎn)擊其實(shí)是使輸入框失去焦點(diǎn)并隱藏鍵盤
知道問題在哪就有解決問題的方向了:點(diǎn)擊列表項(xiàng)使輸入框自動(dòng)失去焦點(diǎn),并觸發(fā)onPress點(diǎn)擊事件。
嘗試方案
- 1.通過點(diǎn)擊事件添加Keyboard.dismiss(),并使用輸入框ref調(diào)用blur()方法
- 2.通過使用Scrollview包裹整個(gè)頁面,添加keyboardShouldPersistTaps={'handled'}設(shè)置項(xiàng)(網(wǎng)上方案)
方案結(jié)果:
- 沒有作用
- 沒有效果,且上面的搜索框會(huì)一起滾動(dòng)
最終方案
通過在技術(shù)群溝通,有位群友提出方案
scrollview 容器加 keyboardDismissMode="on-drag" 實(shí)踐后,并未解決此問題
最終通過嘗試在列表Flatlist中添加屬性keyboardShouldPersistTaps={'always'}
成功解決
示例代碼如下:
// 自定義輸入框 <CustomizeSearchBar value={searchText} actionPress={onActionPress} placeholder='請(qǐng)輸入昵稱/地址/姓名/手機(jī)號(hào)查詢' onSearchChange={onSearchChange}/> <FlatList keyboardShouldPersistTaps={'always'} style={{flex: 1}} data={addressList} renderItem={renderItem} ListEmptyComponent={<ListEmpty type={2} />} keyExtractor={(item) => item.id} /> 復(fù)制代碼
附RN中文網(wǎng)對(duì)keyboardShouldPersistTaps
的解釋說明:
最后
寫了Android和Flutter混合開發(fā)一年多,又開始寫RN了,就想一個(gè)圓一樣。
小伙伴們,你們現(xiàn)在是做RN,Flutter,原生,還是轉(zhuǎn)行了?
以上就是一行代碼教你解決Scrollview和TextInput焦點(diǎn)獲取問題的詳細(xì)內(nèi)容,更多關(guān)于Scrollview TextInput焦點(diǎn)獲取的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Android實(shí)現(xiàn)軟件列表的點(diǎn)擊啟動(dòng)另外一個(gè)程序功能【附demo源碼下載】
這篇文章主要介紹了Android實(shí)現(xiàn)軟件列表的點(diǎn)擊啟動(dòng)另外一個(gè)程序功能,涉及Android針對(duì)應(yīng)用程序的讀取、加載、啟動(dòng)等操作相關(guān)技巧,需要的朋友可以參考下2016-07-07Android P實(shí)現(xiàn)靜默安裝的方法示例(官方Demo)
這篇文章主要介紹了Android P實(shí)現(xiàn)靜默安裝,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02詳解如何在Android Studio中添加RecyclerView-v7支持包
本篇文章主要介紹了詳解如何在Android Studio中添加RecyclerView-v7支持包,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02Android微信右滑退出功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了Android微信右滑退出功能的實(shí)現(xiàn)代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-01-01Android開發(fā)教程之獲取系統(tǒng)輸入法高度的正確姿勢(shì)
這篇文章主要給大家介紹了關(guān)于Android開發(fā)教程之獲取系統(tǒng)輸入法高度的正確姿勢(shì),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Android具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-10-10Android ListView實(shí)現(xiàn)簡(jiǎn)單列表功能
這篇文章主要為大家詳細(xì)介紹了Android ListView實(shí)現(xiàn)簡(jiǎn)單列表功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08