基于React Native 0.52实现轮播图效果


Posted in Javascript onAugust 25, 2020

本文基于React Native 0.52

Demo上传到Git了,有需要可以看看,写了新内容会上传的(Git地址)

一、总览

轮播图几乎是必备的效果,这里选择 react-native-swiper 来实现,效果如下图:

基于React Native 0.52实现轮播图效果

二、实现轮播图效果

1、通过npm安装react-native-swiper

npm install react-native-swiper --save

2、在recommend.js引入react-native-swiper

import Swiper from 'react-native-swiper';

3、用 react-native-swiper 可以很容易的实现轮播的效果

  • showButtons —— 是否显示左右翻页按钮
  • autoPlay —— 是否自动播放
  • paginationStyle —— 包含小点点的容器的样式,这里用来调整位置
  • dotStyle —— 小点点的样式
  • activeDotStyle —— 当前被激活的小点点的样式
<Swiper
  style={styles.wrapper}
  height={width*40/75}
  showsButtons={false}
  autoplay={true}
  paginationStyle={styles.paginationStyle}
  dotStyle={styles.dotStyle}
  activeDotStyle={styles.activeDotStyle}
>
  <Image source={require('../../img/1.jpg')} style={styles.bannerImg} />
  <Image source={require('../../img/2.jpg')} style={styles.bannerImg} />
  <Image source={require('../../img/3.jpg')} style={styles.bannerImg} />
  <Image source={require('../../img/4.jpg')} style={styles.bannerImg} />
  <Image source={require('../../img/3.jpg')} style={styles.bannerImg} />
</Swiper>

样式:

const styles = StyleSheet.create({
 container: {
  flex: 1,
  alignItems: 'center',
  backgroundColor: '#fff',
 },
 bannerImg: {
  height: width*40/75,
  width: width,
 },
 wrapper: {
  width: width,
 },
 paginationStyle: {
  bottom: 6,
 },
 dotStyle: {
  width: 22,
  height: 3,
  backgroundColor:'#fff',
  opacity: 0.4,
  borderRadius: 0,
 },
 activeDotStyle: {
  width: 22,
  height: 3,
  backgroundColor:'#fff',
  borderRadius: 0,
 },
});

三、解决不显示问题

轮播图放在APP的首页,同样有不显示的问题,解决办法和上一篇的办法几乎一样,可以看一下上一篇或是完整代码,这里就不再赘述。

这里和上一篇相比有两处不一样,需要说一下。

1、真正调用接口加载图片的时候,不会出现一开始图片不显示的问题。

2、在状态为false的时候,先显示第一张图片

if (this.state.swiperShow) {
 return (
  <Swiper >
   …………略
  </Swiper>
 )
} else {
 return (
  <View style={{ height: width*40/75 }}>
   <Image source={require('../../img/1.jpg')} style={styles.bannerImg} />
  </View>
 );
}

recommend.js完整代码 地址

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
EasyUI的treegrid组件动态加载数据问题的解决办法
Dec 11 Javascript
国外大牛IE版本检测!现在IE都到9了,IE检测代码
Jan 04 Javascript
Easyui Treegrid改变默认图标的方法
Apr 29 Javascript
js判断所有表单项不为空则提交表单的实现方法
Sep 09 Javascript
利用yarn实现一个webpack+react种子
Oct 25 Javascript
jQuery实现隔行变色的方法分析(对比原生JS)
Nov 18 Javascript
浅析javaScript中的浅拷贝和深拷贝
Feb 15 Javascript
简单实现js菜单栏切换效果
Mar 04 Javascript
jQuery的$.extend 浅拷贝与深拷贝
Mar 08 Javascript
jQuery.form.js的使用详解
Jun 14 jQuery
本地存储localStorage用法详解
Jul 31 Javascript
js实现随机点名功能
Dec 23 Javascript
详解webpack打包后如何调试的方法步骤
Nov 07 #Javascript
微信小程序列表中item左滑删除功能
Nov 07 #Javascript
Angular 实现输入框中显示文章标签的实例代码
Nov 07 #Javascript
VueCli3构建TS项目的方法步骤
Nov 07 #Javascript
vue调试工具vue-devtools安装及使用方法
Nov 07 #Javascript
vue+webpack中配置ESLint
Nov 07 #Javascript
利用jqgrid实现上移下移单元格功能
Nov 07 #Javascript
You might like
实战mysql导出中文乱码及phpmyadmin导入中文乱码的解决方法
2010/06/11 PHP
PHP 面向对象程序设计(oop)学习笔记(一) - 抽象类、对象接口、instanceof 和契约式编程
2014/06/12 PHP
php使用Cookie控制访问授权的方法
2015/01/21 PHP
PHP中类的自动加载的方法
2017/03/17 PHP
PHP简单验证码功能机制实例详解
2019/03/27 PHP
js 加载时自动调整图片大小
2008/05/28 Javascript
基于jquery的finkyUI插件与Ajax实现页面数据加载功能
2010/12/03 Javascript
jquery学习笔记 用jquery实现无刷新登录
2011/08/08 Javascript
getElementByIdx_x js自定义getElementById函数
2012/01/24 Javascript
JavaScript编程的单例设计模讲解
2015/11/10 Javascript
JS+Canvas 实现下雨下雪效果
2016/05/18 Javascript
JavaScript获取ul中li个数的方法
2017/02/13 Javascript
详谈Angular路由与Nodejs路由的区别
2017/03/05 NodeJs
jQuery插件HighCharts绘制2D带Label的折线图效果示例【附demo源码下载】
2017/03/08 Javascript
node.js 抓取代理ip实例代码
2017/04/30 Javascript
vue使用监听实现全选反选功能
2018/07/06 Javascript
详解使用mpvue开发github小程序总结
2018/07/25 Javascript
使用jQuery动态设置单选框的选中效果
2018/12/06 jQuery
jQuery实现ajax的嵌套请求案例分析
2019/02/16 jQuery
Vuejs学习笔记之使用指令v-model完成表单的数据双向绑定
2019/04/29 Javascript
JavaScript中this的学习笔记及用法整理
2020/02/17 Javascript
js+canvas实现纸牌游戏
2020/03/16 Javascript
详解React的回调渲染模式
2020/09/10 Javascript
[01:07:34]DOTA2-DPC中国联赛定级赛 RNG vs Aster BO3第二场 1月9日
2021/03/11 DOTA
Python实现求解括号匹配问题的方法
2018/04/17 Python
利用python开发app实战的方法
2019/07/09 Python
Python decimal模块使用方法详解
2020/06/08 Python
python中scrapy处理项目数据的实例分析
2020/11/22 Python
HTML5 CSS3打造相册效果附源码下载
2014/06/16 HTML / CSS
canvas简单连线动画的实现代码
2020/02/04 HTML / CSS
Bjorn Borg官方网上商店:国际运动时尚品牌
2016/08/27 全球购物
财务管理专业毕业生求职信范文
2013/09/21 职场文书
世界读书日的活动方案
2014/08/20 职场文书
2014年党建工作汇报材料
2014/10/27 职场文书
写给医生的感谢信
2015/01/22 职场文书
未发现nvidia显卡怎么办?Win11系统中未检测到nvidia显卡解决教程
2022/04/08 数码科技