React implements paging effect

React implements paging effect

This article shares the specific code for React to achieve paging effects for your reference. The specific content is as follows

First, make sure antd and axios are installed

jsx file:

import React, { useState, useEffect } from 'react'
import { Pagination } from 'antd';
import './loading.scss'
import Unit from '../hml'
const App = () => {
    // Set the page number const [num, setNum] = useState(1)
    // Obtained data carrier const [data, setData] = useState([])
    //Just used the mount method, secondary acquisition is not easy to useuseEffect(() => {
        Unit.getApi2('/home/mediareports', {
            //Data page page_number: num,
            // How much data per page page_size: 10
        }, {}).then((res) => {
            //Get data setData(res.data.data)
        })
    }, [num])
    const add = (e) => {
        // Each click turns forward one page setNum(e)
    }
    return (
        <>
            <ul>
                {/* map generates data */}
                {
                    data.map((item,index)=>{
                        return <a href={item.jump_url} key={index}><br />
                            {
                                item.main_title
                            }
                        </a>
                            
                    })
                }
            </ul>
            {/* Although the problem here is solved, I don't know why upload e can get the current clicked index instead of the element, but I think it should be related to total*/}
            <Pagination defaultCurrent={num} total={500} onChange={(e)=>add(e)}/>
        </>
    )
}
export default App

loading.scss file:

// antd has no style, the following code can solve this problem @import '~antd/dist/antd.css';

hml.js: (This is the axios package I sent)

import axios from 'axios';
const Unit = {
    async getApi(ajaxCfg){
        let data = await axios.get(ajaxCfg.url,{params:ajaxCfg.cfg},
        {
            headers: ajaxCfg.headers
        })
        return data;
    },
    async getApi2(url,cfg,headers){
        let data = await axios.get(url,{params:cfg},
        {
            headers: headers
        })
        return data;
    },
    async postApi(url,cfg,headers){
        let fd = new FormData();
        for(let key in cfg){
            fd.append(key, cfg[key]);
        }
        let data = await axios.post(url,fd,
        {
            headers: headers
        })
        return data;
    },
    async putApi(url,cfg,headers){
        // import qs from 'qs';
        // let data = await axios.put(url,qs.stringify(cfg),{
        // headers: {
        // 'Content-Type':'application/x-www-form-urlencoded',
        // }
        // })
        // return data;
    },
    async requestApi(cfg,headers,file){
       let fd = new FormData();
       fd.append('param', JSON.stringify(cfg));
       if(file){
           // Upload proof if(file.length){
               for(let i=0,len=file.length;i<len;i++){
                   fd.append('files', file[i]);
               }
           }else {
               // Single upload for(let key in file){
                   fd.append(key, file[key]);
               }
           }
       }
       let data = await axios.post('/batch',fd,
       {
           headers: headers
       })
       return data;
   }
}
export default Unit;

setupProxy.js:

const { createProxyMiddleware } = require('http-proxy-middleware');
module.exports = function (app) {
  app.use(
    // Set the path '/home', createProxyMiddleware({
      target: 'https://home-api.pinduoduo.com',
      changeOrigin: true,
    })
  );
};

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • Try to write a paging component with react yourself (summary)
  • Reactjs implements the example code of the universal paging component
  • React method of displaying data in pages

<<:  MySQL 5.6 compressed package installation method

>>:  Solution for VMware Workstation Pro not running on Windows

Recommend

Detailed explanation of 10 common HTTP status codes

The HTTP status code is a 3-digit code used to in...

How to use mysql to complete the data generation in excel

Excel is the most commonly used tool for data ana...

Vue implements user login and token verification

In the case of complete separation of the front-e...

Summary of Docker common commands and tips

Installation Script Ubuntu / CentOS There seems t...

Linux uses iftop to monitor network card traffic in real time

Linux uses iftop to monitor the traffic of the ne...

Docker installation and configuration steps for MySQL

Table of contents Preface environment Install Cre...

jQuery plugin to achieve seamless carousel

Seamless carousel is a very common effect, and it...

Usage and difference of Js module packaging exports require import

Table of contents 1. Commonjs exports and require...

Linux uses if to determine whether a directory exists.

How to use if in Linux to determine whether a dir...

Proxy realizes the principle of two-way binding of Vue3 data

Table of contents 1. Advantages of proxy vs. Obje...

HTML table markup tutorial (28): cell border color attribute BORDERCOLOR

To beautify the table, you can set different bord...

The most commonly used HTML escape sequence

In HTML, <, >, &, etc. have special mean...

SQL fuzzy query report: ORA-00909: invalid number of parameters solution

When using Oracle database for fuzzy query, The c...

Understanding and example code of Vue default slot

Table of contents What is a slot Understanding of...