目前在Github开源的轮播图控件,我的认为作得比较好的,一个是react-native-swiper(https://github.com/leecade/react-native-swiper),一个是react-native-viewpager(https://github.com/race604/react-native-viewpager),而通过试用发现,react-native-swiper虽然效果和样式较多、控制方便,但在将它缩小为一个固定高度的视图时,其底部的指示符号(即几个点,以下图)就不见了,因此最终我推荐使用react-native-viewpager,简单好用!react
下来咱们将素材和相关的库导入项目当中,其中,react-native-viewpager的添加方法以下:git
npm i -d react-native-viewpager --save
而后在工程的images文件夹中建立banner文件夹,其中放入4个jpg文件:github
1 const BANNER_IMGS = [ 2 require('../images/banner/1.jpg'), 3 require('../images/banner/2.jpg'), 4 require('../images/banner/3.jpg'), 5 require('../images/banner/4.jpg') 6 ];
通过分析,咱们能够看到,首页轮播图的样式十分简单,只须要指定高度,而水平方向,利用flex:1进行拉伸npm
但因为react-native-viewpager做者在构建这个控件的时候,应该是用到一些变量进行控制,并提供了一种方法,用于建立图片数据源,因此,若是须要使用react-native-viewpager必须在构造函数中进行初始化,具体代码以下:react-native
接着,咱们在HomePage类的定义前,建立一个数组常量,用于存放图片:数组
1 constructor(props) { 2 super(props); 3 // 用于构建DataSource对象 4 var dataSource = new ViewPager.DataSource({ 5 pageHasChanged: (p1, p2) => p1 !== p2, 6 }); 7 // 实际的DataSources存放在state中 8 this.state = { 9 dataSource: dataSource.cloneWithPages(BANNER_IMGS) 10 } 11 }
而在render函数中,ViewPager的使用也是至关简单的,具体写法以下:函数
1 <ViewPager 2 style={{height:130}} 3 dataSource={this.state.dataSource} 4 renderPage={this._renderPage} 5 isLoop={true} 6 autoPlay={true} 7 />
其中:oop
style:样式,和其余控件设置方式相似flex
dataSource:即在构造函数中利用dataSource对象和图片数组常量,建立的真实dataSource动画
renderPage:方法类型,返回一段JSX,用于指定ViewPager每页的内容,该方法写法以下,切忌根据WebStorm的提示加上static!:
1 _renderPage(data, pageID) { 2 return ( 3 <Image 4 source={data} 5 style={styles.page}/> 6 ); 7 }
isLoop:是否循环播放,按照示例代码设置便可
autoPlay:是否自动播放,按照示例代码设置便可
locked: 设置为true即禁用ViewPager的点击
onChangePage: 页面切换的回调函数
renderPageIndicator: 自定义指示器样式的渲染
animation:若是以为原始的效果不满意,能够在这个字段中设置一个函数,自定义动画效果
固然,要记得给ViewPager和其中的item添加样式:
1 const styles = StyleSheet.create({ 2 page: { 3 flex: 1, 4 height: 130, 5 resizeMode: 'stretch' 6 } 7 });
保存一下代码,在模拟器上看看效果吧
工程源码及资源文件:https://github.com/yuanguozheng/JdApp
本次Commit:https://github.com/yuanguozheng/JdApp/commit/2d1741bef1c7908c9e0d2f52c23210e8de2fcc7a