我正在开发一个带有本机react的应用程序。我有这个 UI 元素,它类似于 iOS 中的 Maps 元素,您可以在其中从底部和内部滑动一个面板,有一个可滚动列表。
对于滑出式面板,我使用了一个名为rn-sliding-up-panel
. 它有几个props作为事件侦听器。例如
<SlidingUpPanel
allowDragging={/*Boolean*/}
onDragStart={()=>{} /*When it is about to be dragged*/}
onDrag={()=>{} /*When it is being dragged*/}
onDragEnd={()={} /*When the user is no longer touching the screen*/}
></SlidingUpPanel>
在它里面,我有一个<ScrollView>
包含一个<List>
from react-native-elements
。据我所知,它只有一个发泄监听器,是:
<ScrollView onScroll={()=>{}}></ScrollView>
我的问题是在列表上滚动实际上会导致面板关闭(它通过向下滑动关闭)。我通过添加一个状态并在滚动上修改它找到了一种解决方法:
state = {
dragPanel: true,
}
/*===========================================*/
<SlidingUpPanel allowDragging={this.state.dragPanel}>
<ScrollView onScroll={()={ this.setState({dragPanel: false}) }}></ScrollView>
</SlidingUpPanel>
但是,我找不到恢复拖动的方法,并且它的启动效率不高。
TL; 博士
有没有一种有效的方法可以在 SlidingUpPanel 内实现 ScrollView 而没有每个重叠的事件?也许使用类似的东西function(e){e.preventDefault();}
?