用Hooks实现的高性能React-Native Swiper组件
Github仓库: https://github.com/Voyzz/react-native-swiper-hooks
NPM仓库: https://www.npmjs.com/package/react-native-swiper-hooks
data:image/s3,"s3://crabby-images/2ea62/2ea62ce09903f4661e1f0e78204b88397656cd55" alt=""
Hello, folks!
🦄 This is a powerful Swiper hooks component for React Native
✨ 为React Native开发的Swiper Hooks组件
📚 Welcomes to provide your valuable comments or suggestions by ‘Issues’ or my contact information
✨ 欢迎通过”issues“或我的联系方式,为我提供宝贵意见
👨🏻💻 Powered by Voyz Shen
✨ Shanghai Jiao Tong University, Ctrip
Catalog
How to use
installation
1
npm i react-native-swiper-hooks --save
import
1
import Swiper from 'react-native-swiper-hooks'
Useage
1 | ... |
- update height={300}
1
2
3
4
5
6
7
8
9
10npm update react-native-swiper-hooks
```
--
<span id='demo'><span>
## Demo
### autoplay ↓
data:image/s3,"s3://crabby-images/39454/394546cbe5fd444e7d81863c36f05ca860625a2e" alt="autoplay"
paginationSelectedColor={‘#CCFF66’}
autoplay={true}
loop={true}
showPagination={true}
direction={‘row’}height={300}1
2
3
### non-autoplay ↓
data:image/s3,"s3://crabby-images/1bcdc/1bcdcde43e3402cb42a1149d3e5c47b10ff89f24" alt="non_autoplay.gif"
paginationSelectedColor={‘#CCFF66’}
autoplay={false}
loop={true}
showPagination={true}
direction={‘row’}height={300}1
2
3
### non-loop ↓
data:image/s3,"s3://crabby-images/48f60/48f6048b1825b2d252541347279e81caf126be3b" alt="non_loop.gif"
paginationSelectedColor={‘#CCFF66’}
autoplay={false}
loop={false}
showPagination={true}
direction={‘row’}height={300}1
2
3
### vertical scrolling ↓
data:image/s3,"s3://crabby-images/0388b/0388b66e982a7d15b18389cf27e80dbf27c6c35c" alt="vertical_scrolling.gif"
paginationPosition={‘left’}
paginationSelectedColor={‘#CCFF66’}
autoplay={true}
loop={true}
showPagination={true}
direction={‘column’}height={300}1
2
3
### diff Size ↓
data:image/s3,"s3://crabby-images/c5f12/c5f12f8fbabeeae4574827d33540d84cf9004a32" alt="swiper5.gif"
childWidth={WIDTH-100}
paginationSelectedColor={‘#CCFF66’}
autoplay={true}
loop={true}
showPagination={true}
direction={‘row’}
(child:{width=WIDTH-100})1
2
3
### init Index ↓
data:image/s3,"s3://crabby-images/03995/03995b61d7492c6bb0b8e504aa5332a72d4c441f" alt="swipe6.gif"
`
Properties
- Basic -
Prop | Default | Options | Type | Description |
---|---|---|---|---|
width | [width of screen] | / | Number | Width of the Swiper container |
容器宽度 | ||||
height | [height of screen] | / | Number | Height of the Swiper container |
容器高度 | ||||
childWidth | / | / | Number | Width of the child component(when width of container and child component) |
子元素宽度(当子元素宽度与容器宽度不同时传此参数) | ||||
childHeight | / | / | Number | Width of the child component(when height of container and child component) |
子元素高度(当子元素宽度与容器高度不同时传此参数) | ||||
boxBackgroundColor | / | / | Color | Background color of the Swiper container |
容器背景颜色 | ||||
initIndex | 0 | / | Number | Index of the init child |
初始页 | ||||
scrollToIndex | 0 | / | Number | scroll to the child |
参数控制滚动至某子元素 | ||||
direction | ‘row’ | ‘row’ / ‘column’ | String | Direction of the scrolling |
滚动方向 | ||||
minOffset | 10 | / | Number | Threshold of scroll distance for page turning |
翻页的滚动阈值 | ||||
autoplay | true | true / false | Boolean | Enable autoplay |
是否自动播放 | ||||
loop | true | true / false | Boolean | Enable loop mode |
是否循环滚动 | ||||
autoplayGapTime | 3 | / | Number | second between autoplay transitions |
自动播放时间间隔 | ||||
autoplayDirection | true | true / false | Boolean | Enable forward direction when autoplay |
是否正向自动播放 | ||||
scrollEnabled | true | true / false | Boolean | Enable hand-rolling |
是否可以手动滚动 | ||||
animated | true | true / false | Boolean | Enable smooth scrolling animation |
是否开启滚动动画 | ||||
bounces | true | true / false | Boolean | Enable pull flexibly when you scroll to the head and tail |
到达首尾时是否可以弹性拉动一截 |
- Pagination -
Prop | Default | Options | Type | Description |
---|---|---|---|---|
showPagination | true | true / false | Boolean | Enable pagination shower |
是否显示页码器 | ||||
paginationDirection | ‘bottom’ | ‘bottom’ / ‘top’ / ‘left’ / ‘right’ | String | Position of the pagination |
页码器位置 | ||||
paginationOffset | 5 | / | Number | Distance between pagination shower and side |
页码器距边距离 | ||||
paginationUnselectedSize | 6 | / | Number | Size of the point (non-current) |
提示点大小(非当前页) | ||||
paginationSelectedSize | 10 | / | Number | Size of the point (current) |
提示点大小(当前页) | ||||
paginationUnselectedColor | ‘#FFFFFF’ | / | Color | Color of the point (non-current) |
提示点颜色(非当前页) | ||||
paginationSelectedSize | ‘#000000’ | / | Color | Color of the point (current) |
提示点颜色(当前页) |
Functions
- callback -
Func | Params | Type | Description |
---|---|---|---|
onPaginationChange | index | Number | Retrun the index of current page when it changes |
页码改变时返回当前页码索引 | |||
onScrollBeginDrag | nativeEvent | Object | Callback on scroll begin drag |
开始拖动时的回调函数 | |||
onScrollEndDrag | nativeEvent | Object | Callback on scroll end drag |
结束拖动时的回调函数 | |||
getScrollDistance | / | int | get distance on scrolling |
获取手动滚动距离 | |||
getChildrenOnPageinationChange | / | int | get JSX Array of Children |
获取JSX数组 |
Versions
v1.2.4
[性能优化] 避免scrollToIndex与自动播放的冲突
v1.2.3
[添加新方法] getChildrenOnPageinationChange获取JSX数组
v1.2.2
[添加新参数] scrollToIndex参数控制滚动至某子元素
v1.2.1
[添加新方法] 获取手动滚动距离
[性能优化] 优化手动滚动时与自动滚动的冲突v1.2.0
[添加新功能] 允许swiper内子元素尺寸与容器尺寸不同
v1.1.3
[性能优化] 修复页码器更新延迟
[bug修复] 修复循环模式下翻页至页尾时的bugv1.1.2
更新文档
v1.1.1
[bug修复] 修复安卓循环模式下翻页闪屏问题
v1.1.0
组件项目迁移