亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

嘗試自己動手用react來寫一個分頁組件(小結)

2019-11-19 14:22:27
字體:
來源:轉載
供稿:網友

本文介紹了嘗試自己動手用react來寫一個分頁組件(小結),分享給大家,具體如下:

分頁效果

在線預覽

github地址

效果截圖(樣式可自行修改):

構建項目

create-react-app react-paging-component

分頁組件

1.子組件

創建 Pagecomponent.js 文件

核心代碼:

初始化值

 constructor(props) {    super(props)    this.state = {      currentPage: 1, //當前頁碼      groupCount: 5, //頁碼分組,顯示7個頁碼,其余用省略號顯示      startPage: 1, //分組開始頁碼      totalPage:1 //總頁數    }  }

動態生成頁碼函數

createPage() {    const {currentPage, groupCount, startPage,totalPage} = this.state;    let pages = []    //上一頁    pages.push(<li className={currentPage === 1 ? "nomore" : null} onClick={this.prePageHandeler.bind(this)}            key={0}>      上一頁</li>)    if (totalPage <= 10) {      /*總頁碼小于等于10時,全部顯示出來*/      for (let i = 1; i <= totalPage; i++) {        pages.push(<li key={i} onClick={this.pageClick.bind(this, i)}                className={currentPage === i ? "activePage" : null}>{i}</li>)      }    } else {      /*總頁碼大于10時,部分顯示*/      //第一頁      pages.push(<li className={currentPage === 1 ? "activePage" : null} key={1}              onClick={this.pageClick.bind(this, 1)}>1</li>)      let pageLength = 0;      if (groupCount + startPage > totalPage) {        pageLength = totalPage      } else {        pageLength = groupCount + startPage;      }      //前面省略號(當當前頁碼比分組的頁碼大時顯示省略號)      if (currentPage >= groupCount) {        pages.push(<li className="" key={-1}>???</li>)      }      //非第一頁和最后一頁顯示      for (let i = startPage; i < pageLength; i++) {        if (i <= totalPage - 1 && i > 1) {          pages.push(<li className={currentPage === i ? "activePage" : null} key={i}                  onClick={this.pageClick.bind(this, i)}>{i}</li>)        }      }      //后面省略號      if (totalPage - startPage >= groupCount + 1) {        pages.push(<li className="" key={-2}>???</li>)      }      //最后一頁      pages.push(<li className={currentPage === totalPage ? "activePage" : null} key={totalPage}              onClick={this.pageClick.bind(this, totalPage)}>{totalPage}</li>)    }    //下一頁    pages.push(<li className={currentPage === totalPage ? "nomore" : null}            onClick={this.nextPageHandeler.bind(this)}            key={totalPage + 1}>下一頁</li>)    return pages;  }

頁碼點擊函數:

//頁碼點擊  pageClick(currentPage) {    const {groupCount} = this.state    const getCurrentPage = this.props.pageCallbackFn;    //當 當前頁碼 大于 分組的頁碼 時,使 當前頁 前面 顯示 兩個頁碼    if (currentPage >= groupCount) {      this.setState({        startPage: currentPage - 2,      })    }    if (currentPage < groupCount) {      this.setState({        startPage: 1,      })    }    //第一頁時重新設置分組的起始頁    if (currentPage === 1) {      this.setState({        startPage: 1,      })    }    this.setState({      currentPage    })    //將當前頁碼返回父組件    getCurrentPage(currentPage)  }

上一頁和夏夜點擊事件

//上一頁事件  prePageHandeler() {    let {currentPage} = this.state    if (--currentPage === 0) {      return false    }    this.pageClick(currentPage)  }  //下一頁事件  nextPageHandeler() {    let {currentPage,totalPage} = this.state    // const {totalPage} = this.props.pageConfig;    if (++currentPage > totalPage) {      return false    }    this.pageClick(currentPage)  }

組件渲染到DOM上

render() {    const pageList = this.createPage();    return (      <ul className="page-container">        {pageList}      </ul>    )  }

2.父組件

創建 Pagecontainer.js 文件

父組件完整代碼

import React, {Component} from 'react'import Pagecomponent from '../components/Pagecomponent'import data from '../mock/tsconfig.json'class Pagecontainer extends Component {  constructor() {    super()    this.state = {      dataList:[],      pageConfig: {        totalPage: data.length //總頁碼      }    }    this.getCurrentPage = this.getCurrentPage.bind(this)  }  getCurrentPage(currentPage) {    this.setState({      dataList:data[currentPage-1].name    })  }  render() {    return (      <div>        <div>          {this.state.dataList}        </div>        <Pagecomponent pageConfig={this.state.pageConfig}                pageCallbackFn={this.getCurrentPage}/>      </div>    )  }}export default Pagecontainer

至此一個分頁組件就開發完了,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品情侣自拍| 97av在线影院| 91久久精品国产91久久性色| 欧美性猛交xxxx免费看久久久| 成人精品一区二区三区电影免费| 亚洲精品综合久久中文字幕| 91日韩在线视频| 日韩电影中文字幕av| 亚洲国产精品一区二区三区| 国产成人欧美在线观看| 久久久精品中文字幕| 精品国产91久久久| 欧美性感美女h网站在线观看免费| 国产亚洲视频在线观看| 亚洲人成伊人成综合网久久久| 久久97精品久久久久久久不卡| 亚洲美女又黄又爽在线观看| 色综合久久88| 北条麻妃一区二区在线观看| 亚洲成人激情在线| 日韩在线观看免费全集电视剧网站| 97视频在线看| 夜夜嗨av一区二区三区四区| 日韩欧美亚洲综合| 欧美激情性做爰免费视频| 2018中文字幕一区二区三区| 狠狠色狠色综合曰曰| 日韩大陆欧美高清视频区| 另类美女黄大片| 久久av中文字幕| 久久躁日日躁aaaaxxxx| 亚洲日本aⅴ片在线观看香蕉| 性日韩欧美在线视频| 国产精品三级久久久久久电影| 68精品国产免费久久久久久婷婷| 国产精品丝袜久久久久久不卡| xx视频.9999.com| 伊人久久大香线蕉av一区二区| 欧美日韩国产二区| 久久久成人的性感天堂| 最近2019中文字幕mv免费看| 日韩女优人人人人射在线视频| 久久精品亚洲国产| 国产精品欧美日韩久久| 欧美在线视频一区二区| 26uuu另类亚洲欧美日本一| 日韩av在线电影网| 国产日韩欧美在线看| 91九色国产视频| 97在线精品国自产拍中文| 欧美极品在线视频| 国产精品网红福利| 91高清在线免费观看| 国产精品综合久久久| 成人国产精品免费视频| 久久久久久亚洲| 亚洲在线免费视频| 色婷婷av一区二区三区久久| 亚洲区一区二区| 欧美乱大交做爰xxxⅹ性3| 国产国语videosex另类| 亚洲91精品在线观看| 日韩精品中文在线观看| 国产精品久久久久久久9999| 欧美大片免费观看在线观看网站推荐| 国产啪精品视频| 不卡av电影在线观看| 午夜免费日韩视频| 欧美国产极速在线| 成人在线观看视频网站| 欧美裸体xxxx极品少妇| 中文一区二区视频| 欧美日韩国产色| 久久免费精品日本久久中文字幕| 555www成人网| 一区二区三区四区精品| 精品久久久久久久久久ntr影视| 久久综合国产精品台湾中文娱乐网| 成人免费xxxxx在线观看| 国产精品久久久久久久久久久新郎| 奇米一区二区三区四区久久| 日韩有码片在线观看| 色婷婷亚洲mv天堂mv在影片| 日韩亚洲精品电影| 欧美精品久久久久久久免费观看| 日韩av大片在线| 福利一区福利二区微拍刺激| 久久777国产线看观看精品| 亚洲乱码国产乱码精品精| 国产主播在线一区| 亚洲成人a级网| 精品五月天久久| 国产亚洲欧美日韩美女| 欧美wwwxxxx| 欧美日韩国产成人高清视频| 韩国三级日本三级少妇99| 国产日韩欧美影视| 亚洲国产精彩中文乱码av| 久久国产天堂福利天堂| 亚洲sss综合天堂久久| 国产精品久久久久免费a∨大胸| 国内精品久久久久久中文字幕| 精品视频久久久| 欧美激情一区二区三区成人| 成人久久久久久久| 欧美精品久久久久久久| 久久精品在线播放| 亚洲成人a**站| 色无极亚洲影院| 俺去了亚洲欧美日韩| 国模吧一区二区三区| 亚洲美女喷白浆| 国产97在线亚洲| 91国内精品久久| 国产中文欧美精品| 亚洲一二三在线| 久热国产精品视频| 久久综合伊人77777尤物| 57pao成人国产永久免费| 欧美香蕉大胸在线视频观看| 国产精品视频在线播放| 欧美精品激情在线观看| 91成人在线视频| 久久久亚洲网站| 欧美激情在线观看| 日韩欧美a级成人黄色| 欧美黑人巨大精品一区二区| 欧美日韩精品国产| 欧美极品第一页| 国产精品wwwwww| 国产成人精品免高潮在线观看| 欧美日韩激情美女| 国产不卡一区二区在线播放| 两个人的视频www国产精品| 色婷婷久久一区二区| 亚洲欧美日韩国产成人| 国产精品福利观看| 欧美激情在线视频二区| 亚洲精品www久久久久久广东| 亚洲精品在线观看www| 欧美国产日韩一区| 亚洲国产精品字幕| 欧美日韩亚洲精品一区二区三区| 欧美亚洲伦理www| 亚洲男人天堂2019| 国产精品久久久久久久久久ktv| 国产z一区二区三区| 精品久久中文字幕久久av| 国模视频一区二区| 91精品免费看| 国产mv久久久| 亚洲在线观看视频网站| 国产日韩精品在线观看| 亚洲精品之草原avav久久| 欧美俄罗斯乱妇| 久久婷婷国产麻豆91天堂| 中文字幕亚洲欧美日韩在线不卡| 中文字幕亚洲天堂| 国产精品va在线播放我和闺蜜| 精品中文字幕乱| 亚洲欧洲黄色网| 精品国产网站地址| 欧美精品在线播放| 2020国产精品视频|