我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么用React完成一个图片轮播组件

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么用React完成一个图片轮播组件

这篇文章主要为大家展示了“怎么用React完成一个图片轮播组件”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么用React完成一个图片轮播组件”这篇文章吧。

  使用React实现上述功能,首先,划分组件:

  <SlideMS><SlideM/>

  <SlideS/><SlideMS/>

  组件SlideM代表中图组件,其始终维护一个state:currentMIndex,即当前的中图图片的index值。

  组件SlideS代表小图组件,要维护两个state:currentSIndex,currentSPage,即当前的小图图片的index值和小图当前的页数;

  外层组件SlideMS接受几个参数作为props:

  <SlideMSmediumImageArr={mediumImageArr}eachMediumImgWidth={616}smallImageArr={smallImageArr}eachSmallImgWidth={82}/>,document.getElementById('js-img-slide'));

  SlideM、SlideS再从SlideMS中获取参数进行内部渲染。

  <SlideMmediumImageArr={mediumImageArr}currentMIndex={currentMIndex}eachMediumImgWidth={eachMediumImgWidth}callback={(index)=>{self.setSmallIndex(index)}}/><SlideSsmallImageArr={smallImageArr}currentSIndex={currentSIndex}eachSmallImgWidth={eachSmallImgWidth}eachMediumImgWidth={eachMediumImgWidth}callback={(index)=>{self.setMediumIndex(index)}}/>

  当点击中图的切换按钮时,计算图片偏移量,然后将新的currentMIndex传递给父组件,父组件setState通知两个子组件currentMIndex发生了改变;

  小图组件中涉及的计算比较多,可以将这些抽成方法,例如:根据给定的中图宽度计算一页有几张小图、计算小图总页数、根据给定的index值判断小图处于当前哪一页等。

  当点击小图组件的左右箭头时,计算图片的偏移量(首先计算一张中图里有几张小图),然后setState修改小图currentSPage的值。父组件setState通知两个子组件currentMIndex发生了改变;

  中图、小图组件分别在componentWillReceiveProps里接收到了新的值的改变后,重新setState,更新组件内部的state,就实现了两者之间的通信。

  以上是实现的一个思路。在实际应用中,场景会复杂一些,例如,第一张图片可能存在播放视频的需求,还有当点击中图图片时,能切换到大图模式,大图模式下能正常轮播,并且在关闭大图模式时,中图和小图自动定位到刚才最后一张浏览的图片。这时会涉及稍微复杂一些的运算,需要在此基础上做一下兼容。

  非常尴尬的一点:图片轮播时的动画效果,依旧使用了jquery的animate.

以上是“怎么用React完成一个图片轮播组件”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么用React完成一个图片轮播组件

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么用AdapterViewFlipper轻松完成图片轮播

这篇文章将为大家详细讲解有关怎么用AdapterViewFlipper轻松完成图片轮播,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、认识AdapterViewFilpper AdapterVie
2023-06-14

使用AmazeUI怎么实现一个图片轮播效果

使用AmazeUI怎么实现一个图片轮播效果?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
2023-06-09

怎么用vue写一个轮播图

本篇内容主要讲解“怎么用vue写一个轮播图”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用vue写一个轮播图”吧!1.先展示最终效果:2.解决思路Vue的理念是以数据驱动视图,所以拒绝通过改
2023-07-04

使用CSS3怎么实现一个切片式图片轮播效果

使用CSS3怎么实现一个切片式图片轮播效果?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。css是什么意思css是一种用来表现HTML或XML等文件样式的计算机语
2023-06-08

怎么使用vue轮播组件vue-awesome-swiper实现轮播图

这篇文章主要讲解了“怎么使用vue轮播组件vue-awesome-swiper实现轮播图”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用vue轮播组件vue-awesome-swipe
2023-07-04

使用JavaScript怎么模仿一个京东轮播图效果

今天就跟大家聊聊有关使用JavaScript怎么模仿一个京东轮播图效果,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。主要技术点:每隔3秒自动切换图片;鼠标移入图片自动暂停切换,鼠标移
2023-06-06

怎么用React撸一个日程组件

本篇内容主要讲解“怎么用React撸一个日程组件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用React撸一个日程组件”吧!目录结构└─Calendar │ data.d.ts
2023-06-05

使用react怎么实现一个Radio组件

使用react怎么实现一个Radio组件?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。测试组件:class Test extends Component { constr
2023-06-14

怎么使用react实现一个tab组件

使用react实现一个tab组件的方法:1、通过“export default props => {...}”方式创建TAB button组件;2、通过“tab-group-layout.js”组件来传“tabIndex”,并设置默认选中的tab效果;3、用react继承“react.component”组件里的onMouseOver和OnMouseOut方法即可。
2022-11-22

怎么在Andriod使用多线程实现一个轮播图功能

这篇文章将为大家详细讲解有关怎么在Andriod使用多线程实现一个轮播图功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。MainActivity了初始化控件。
2023-05-30

怎么在videojs中使用swiper实现一个商品详情轮播图

本篇文章给大家分享的是有关怎么在videojs中使用swiper实现一个商品详情轮播图,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。HTML部分: