购物车的功能基本上电商项目都会有的,这是一篇关于react-native的,原生android的已经好久没写了。记得以前写原生购物车的时候,遇到过产品的灵魂质问,为啥iOS的滑动删除可以,android却那么难实现的。这个时候,我就打开微信说,android的微信版也是长按进行操作,iOS的是滑动操作的,两个平台自带的系统交互操作是不一样的。当然,最后还是默默的找各种三方库去进行滑动删除。
rn的项目也是找的网上的一个三方库进行列表滑动操作的,github地址react-native-swipe-list-view
最基本的使用方法和flatList差不多,data 属性数组数据源,renderItem 从data中挨个取出数据并渲染到列表中
1
2
3
4
5
|
<SwipeListView
data={ this .state.listViewData}
renderItem={ this .renderItem}
keyExtractor={ this .keyExtractor}
/>
|
这时候是不可以左右滑动的,就跟普通的flatList效果一样。加上renderHiddenItem属性,可以左右滑动。renderHiddenItem渲染的就是隐藏的内容,隐藏的内容位置是通过flex布局来控制,下面这个例子使用横向布局,通过space-between将内容控制在左右两边,形成了左右滑动时出现隐藏内容。
1
2
3
4
5
6
7
8
9
10
11
|
//这是左右都可以滑动的
renderHiddenItem = (data, rowMap) => {
return <View style={{
flex: 1,
flexDirection: 'row' ,
justifyContent: 'space-between'
}}>
<Text>Left</Text>
<Text>Right</Text>
</View>
}
|
我们这边只需要可以左滑,通过justifyContent: 'flex-end'属性将删除按钮内容置于最右边,同时设置SwipeListView的属性disableRightSwipe来禁止右滑操作。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
renderHiddenItem = (data, rowMap) => {
return <View style={{
flex: 1,
flexDirection: 'row' ,
justifyContent: 'flex-end' ,
}}>
<TouchableOpacity style={{
backgroundColor: '#FF496C' ,
width: 80,
justifyContent: 'center' ,
alignItems: 'center'
}}>
<Text style={{color: '#fff' }}>删除</Text>
</TouchableOpacity>
</View>
}
|
这个时候向左滑,可以看到右边的删除按钮出来了,但是没有一直处于打开状态,还需要添加rightOpenValue={-80}属性,使其处于打开状态。
1
2
3
4
5
6
7
8
|
<SwipeListView
disableRightSwipe
data={ this .state.listViewData}
renderItem={ this .renderItem}
keyExtractor={ this .keyExtractor}
renderHiddenItem={ this .renderHiddenItem}
rightOpenValue={-80}
/>
|
另外有一个需要注意的是,renderItem进行列表渲染时,最外层的视图,官方推荐使用可点击响应触摸的,而不是<View/>,正常情况是,打开了一个视图,点其他视图,默认会关闭打开的那一项,如果最外层是<View/>则不会有这种效果。
1
2
3
4
5
6
7
8
9
|
//最外层是 TouchableHighlight
renderItem = ({item, index}, rowMap) => {
return <TouchableHighlight
onPress={() => {
}}
underlayColor={ '#fff' }>
...
</TouchableHighlight>
}
|
至此,滑动删除的效果已经基本满足了,后续就是业务逻辑,增删操作数据源刷新页面了。
到此这篇关于react-native 实现购物车滑动删除效果的示例代码的文章就介绍到这了,更多相关react-native 滑动删除内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://juejin.cn/post/6917609565685055502