这篇文章主要为大家展示了“怎么用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完成一个图片轮播组件”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。