欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React翻頁器的實(shí)現(xiàn)(包含前后端)

 更新時(shí)間:2021年08月06日 10:25:57   作者:xiaoff  
本文主要介紹了React翻頁器的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

前端

首先需要熟悉前端react中table中的屬性pagination

<Pagination onChange={onChange} total={50} />

<Table bordered columns={columns} rowKey={record => record.id} dataSource={dataSource}
       pagination={pagination}/>

其中pagination我們自己去實(shí)現(xiàn)的函數(shù),因?yàn)樵趓eact中只給出靜態(tài)樣例
我們可以去查看react文檔中,給的示例的是如下圖

 

其中提示我們函數(shù)的參數(shù)為current及pageSize
那么我們可以按照文檔中的提示去思考
是否可以給函數(shù)傳入當(dāng)前頁和每頁的最大數(shù)據(jù)量

按照上面的思路去設(shè)計(jì)與寫翻頁器的函數(shù)

const pagination = {
    showQuickJumper:true,
    showSizeChanger:[],
    total: this.example.total,
    defaultCurrent: this.example.page,
    current: this.example.page,
    pageSize: this.example.pageSize,
    hasNextPage: this.example.hasNextPage,
    onShowSizeChange: (current, size) => {
         // 每頁的最大數(shù)據(jù)量
        self.example.pageSize = size;
        // 當(dāng)前頁
        self.example.page = current;
        // 將兩個(gè)參數(shù)封裝在一個(gè)temple中
        let temple = {
            page : self.example.page,
            pageSize : self.example.pageSize
        };
        // 最終重新去請(qǐng)求函數(shù),將當(dāng)前頁與每頁的數(shù)據(jù)最大量傳入重新請(qǐng)求的參數(shù)
        self.onFetch(temple);
    },
    onChange(current, pageSize) {
        self.example.pageSize = pageSize;
        self.example.page = current;
        
        let temple = {
            page : self.data.search.page,
            pageSize : self.data.search.pageSize,
        };
        self.onFetch(temple);
    }
};

此刻我們已經(jīng)實(shí)現(xiàn)了翻頁器的前端的函數(shù)
那么就可以在table中的pagination中傳入pagination

后端(以java為例)

首先我們需要寫一條SQL

select id from stu limit ${(page - 1)*(pageSize)}, ${pageSize + 1}

解讀SQL,有人可能會(huì)問pageSize為什么會(huì)加1
因?yàn)槔?/p>

countSize是201 pageSize是20 你直接除結(jié)果是10 但是實(shí)際上需要的是11

我們后端可以使用mybatis-helper或者自己封裝PageList
最終可以將從數(shù)據(jù)庫中查出的數(shù)據(jù)放到PageList中,再返回給前端
前端會(huì)收到后端傳入的數(shù)據(jù)總數(shù)(total)每頁的最大數(shù)量(pageSize)

對(duì)于SQL傳參的問題

當(dāng)我們寫

SELECT
 id
FROM
 stu
LIMIT 1,10

查出的數(shù)據(jù)是 218 222 220 217 219 221 8 9 10 12
如果我們把1改成2,那么查出的數(shù)據(jù)為 222 220 217 219 221 8 9 10 12 14
這就是我們?yōu)槭裁丛趕ql里面寫的是(page - 1)*(pageSize)
因?yàn)楫?dāng)limit傳入10,10的時(shí)候才能真正將數(shù)據(jù)刷新一遍
否則前端傳入page=2的時(shí)候,我們只在后端更新了一條數(shù)據(jù),而重疊了相當(dāng)于pageSize-1的數(shù)據(jù)量

注意

當(dāng)我們SQL寫成(page-1)的時(shí)候,前端的默認(rèn)頁一定要傳入的值從1開始,否則傳入0,就會(huì)出現(xiàn)負(fù)數(shù)
我們的后端就會(huì)產(chǎn)生報(bào)錯(cuò)

關(guān)于如何優(yōu)化limit,可以參考我的另一篇文章「深究MySQL之select優(yōu)化

到此這篇關(guān)于React翻頁器的實(shí)現(xiàn)(包含前后端)的文章就介紹到這了,更多相關(guān)React翻頁器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:

相關(guān)文章

  • React?狀態(tài)管理工具優(yōu)劣勢示例分析

    React?狀態(tài)管理工具優(yōu)劣勢示例分析

    這篇文章主要為大家介紹了React?狀態(tài)管理工具優(yōu)劣勢示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • 淺析React中的受控組件和非受控組件

    淺析React中的受控組件和非受控組件

    具體來說這是一種react非受控組件,其狀態(tài)是在input的react內(nèi)部控制,不受調(diào)用者控制。可以使用受控組件來實(shí)現(xiàn)。下面就說說這個(gè)React中的受控組件與非受控組件的相關(guān)知識(shí),感興趣的朋友一起看看吧
    2021-05-05
  • 如何用react優(yōu)雅的書寫CSS

    如何用react優(yōu)雅的書寫CSS

    這篇文章主要介紹了如何用react優(yōu)雅的書寫CSS,幫助大家更好的理解和學(xué)習(xí)使用react,感興趣的朋友可以了解下
    2021-04-04
  • react項(xiàng)目中redux的調(diào)試工具不起作用的解決

    react項(xiàng)目中redux的調(diào)試工具不起作用的解決

    這篇文章主要介紹了react項(xiàng)目中redux的調(diào)試工具不起作用的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • react開發(fā)教程之React 組件之間的通信方式

    react開發(fā)教程之React 組件之間的通信方式

    本篇文章主要介紹了react開發(fā)教程之React組件通信詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-08-08
  • React+Koa實(shí)現(xiàn)文件上傳的示例

    React+Koa實(shí)現(xiàn)文件上傳的示例

    這篇文章主要介紹了React+Koa實(shí)現(xiàn)文件上傳的示例,幫助大家更好的理解和學(xué)習(xí)使用React,感興趣的朋友可以了解下
    2021-04-04
  • React數(shù)據(jù)傳遞之組件內(nèi)部通信的方法

    React數(shù)據(jù)傳遞之組件內(nèi)部通信的方法

    這篇文章主要介紹了React數(shù)據(jù)傳遞之組件內(nèi)部通信的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-12-12
  • React?Context用法小結(jié)(附完整代碼)

    React?Context用法小結(jié)(附完整代碼)

    這篇文章主要介紹了React?Context用法小結(jié)(附完整代碼),Context提供了一種新的組件之間共享數(shù)據(jù)的方式,允許數(shù)據(jù)隔代傳遞,而不必顯式的通過組件樹逐層傳遞props,本文通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • React控制元素顯示隱藏的三種方法小結(jié)

    React控制元素顯示隱藏的三種方法小結(jié)

    這篇文章主要介紹了React控制元素顯示隱藏的三種方法小結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • react項(xiàng)目中express動(dòng)態(tài)路由未能匹配造成的404問題解決

    react項(xiàng)目中express動(dòng)態(tài)路由未能匹配造成的404問題解決

    本文主要介紹了react項(xiàng)目中express動(dòng)態(tài)路由未能匹配造成的404問題解決,解決了白屏的問題,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09

最新評(píng)論