91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現React翻頁器

發布時間:2021-08-06 11:13:31 來源:億速云 閱讀:243 作者:小新 欄目:開發技術

這篇文章主要為大家展示了“如何實現React翻頁器”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“如何實現React翻頁器”這篇文章吧。

前端

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

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

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

其中pagination我們自己去實現的函數,因為在react中只給出靜態樣例
我們可以去查看react文檔中,給的示例的是如下圖

 如何實現React翻頁器

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

按照上面的思路去設計與寫翻頁器的函數

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) => {
         // 每頁的最大數據量
        self.example.pageSize = size;
        // 當前頁
        self.example.page = current;
        // 將兩個參數封裝在一個temple中
        let temple = {
            page : self.example.page,
            pageSize : self.example.pageSize
        };
        // 最終重新去請求函數,將當前頁與每頁的數據最大量傳入重新請求的參數
        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);
    }
};

此刻我們已經實現了翻頁器的前端的函數
那么就可以在table中的pagination中傳入pagination

后端(以java為例)

首先我們需要寫一條SQL

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

解讀SQL,有人可能會問pageSize為什么會加1
因為例如

countSize是201 pageSize是20 你直接除結果是10 但是實際上需要的是11

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

對于SQL傳參的問題

當我們寫

SELECT
 id
FROM
 stu
LIMIT 1,10

查出的數據是 218 222 220 217 219 221 8 9 10 12
如果我們把1改成2,那么查出的數據為 222 220 217 219 221 8 9 10 12 14
這就是我們為什么在sql里面寫的是(page - 1)*(pageSize)
因為當limit傳入10,10的時候才能真正將數據刷新一遍
否則前端傳入page=2的時候,我們只在后端更新了一條數據,而重疊了相當于pageSize-1的數據量

注意

當我們SQL寫成(page-1)的時候,前端的默認頁一定要傳入的值從1開始,否則傳入0,就會出現負數
我們的后端就會產生報錯。

以上是“如何實現React翻頁器”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

绥中县| 镇平县| 邢台市| 当涂县| 山阴县| 阆中市| 扶余县| 承德县| 天全县| 栾川县| 海丰县| 贡觉县| 九江县| 株洲县| 易门县| 静海县| 大名县| 周宁县| 衡阳市| 纳雍县| 景洪市| 大渡口区| 曲麻莱县| 石嘴山市| 稻城县| 田东县| 奉化市| 喜德县| 泰和县| 盘山县| 安西县| 谷城县| 台北县| 宁明县| 彩票| 衢州市| 曲麻莱县| 安丘市| 芒康县| 兴城市| 西乌珠穆沁旗|