React實現(xiàn)輪播效果
更新時間:2020年08月25日 11:26:24 作者:越來越好。
這篇文章主要為大家詳細(xì)介紹了React實現(xiàn)輪播效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了React實現(xiàn)輪播,供大家參考,具體內(nèi)容如下
思路
1、使用全局的state進(jìn)行狀態(tài)管理
2、設(shè)置全局下標(biāo),對當(dāng)前的圖片下表進(jìn)行樣式劃分
3、定時循環(huán)人物便利改變?nèi)窒聵?biāo)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <style> ul{ width: 100%; text-align: center; list-style-type: circle; } ul>li{ width: 2%; float: left; } img{ width: 100%; } </style> <title>輪播事件</title> </head> <body> <div id="root" style="max-width: 700px;margin: 0 auto;"></div> </body> <script src="./js/react.development.js"></script> <script src="./js/react-dom.development.js"></script> <script src="./js/babel.min.js"></script> <script type="text/babel"> window.onload=()=>{ class Img extends React.Component{ constructor(props) { super(props); this.state={ listImg:[ './img/banner1.jpg', './img/banner2.jpg', './img/banner3.jpg', './img/banner4.jpg', './img/banner5.jpg', ], index:0 } } //計時器執(zhí)行 indexChange(){ if(this.state.index == this.state.listImg.length-1){ this.setState({ index:0 }) }else{ // this.state.index++; this.setState({ index:this.state.index+1 }) console.log(this.state.index); } } componentDidMount(){ setInterval(()=>{ this.indexChange(); },2000) } render(){ let {listImg,index} = this.state; let imgList=listImg.map((item,imgIndex)=>{ return <img src={item} key={imgIndex} style={{'display':index == imgIndex ? 'block' : 'none'}} className='img'/> }) let liList=listImg.map((item2,imgIndex2)=>{ return <li key={imgIndex2} style={{'listStyleType':index == imgIndex2 ? 'initial' :'circle'}}></li> }) return ( <div> {imgList} <div> <ul> {liList} </ul> </div> </div> ) } } ReactDOM.render( <Img />, document.getElementById("root") ) } </script> </html>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解webpack + react + react-router 如何實現(xiàn)懶加載
這篇文章主要介紹了詳解webpack + react + react-router 如何實現(xiàn)懶加載,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-11-11詳解React setState數(shù)據(jù)更新機(jī)制
這篇文章主要介紹了React setState數(shù)據(jù)更新機(jī)制的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用React框架,感興趣的朋友可以了解下2021-04-04React?中使用?Redux?的?4?種寫法小結(jié)
這篇文章主要介紹了在?React?中使用?Redux?的?4?種寫法,Redux 一般來說并不是必須的,只有在項目比較復(fù)雜的時候,比如多個分散在不同地方的組件使用同一個狀態(tài),本文就React使用?Redux的相關(guān)知識給大家介紹的非常詳細(xì),需要的朋友參考下吧2022-06-06React路由組件傳參的三種方式(params、search、state)
本文主要介紹了React路由組件傳參的三種方式,主要包括了params、search、state,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07