Vue encapsulates the public function method of exporting Excel data

Vue encapsulates the public function method of exporting Excel data

vue+element UI encapsulates a public function to export Excel data

Encapsulate the public methods in the common.js of the store's modules, as shown below:

insert image description here

The code is as follows:

const download = {
    actions: {
        downloadData({ commit, state }, data) {
            return new Promise((resolve, reject) => {
                data.event(data.formData).then(res => {
                    const blob = new Blob([res.data], {
                        type: 'application/vnd.ms-excel'
                    })
                    const objectUrl = URL.createObjectURL(blob)
                    const link = document.createElement('a') // Create a tag link.href = objectUrl
                    // Rename the file link.download = res.headers['content-disposition'].split(
                        '='
                    )[1]
                    link.click()
                    URL.revokeObjectURL(objectUrl)
                    resolve(res)
                }).catch((err) => {
                    reject(err)
                })
            })
        }

    }

}

export default download

Then export it to the public module in the store's index

insert image description here

insert image description here

Use in components that need to call methods

methods: {
       //Method for exporting data handleExport(formData) {
            this.loading = true
            const data = {
            // import { loanDownloadData } from '@/api/loan/userLoanList'
            // event: loanDownloadData, loanDownloadData is the keyword of the interface for exporting data //formData is the parameter required by the loanDownloadData interface event: '', 
                formData: formData
            }
            this.$store.dispatch('downloadData', data).then(res => {
                this.loading = false
            }).catch(() => {
                this.loading = false
            })
        },

}

PS: If the interface can return data normally, but an error occurs when calling the interface, it may be that the data returned by the interface interception file is incorrect. First find the utils->request.js file (usually placed in this location), as follows:

insert image description here

When the interface is intercepted, if the export interface needs to return all the data, such as response, because the headers rename file needs to be used in the common.js file, as follows

insert image description here

In general, interface interception only needs to return data, such as: const res = response.data, return res

insert image description here

This is the end of this article about Vue encapsulation of public functions for exporting Excel data. For more relevant Vue export Excel public function content, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • How to export the excel file returned by the backend in Vue front end
  • Vue requests the backend interface to export excel tables
  • How to use js-xlsx to export excel in vue
  • Detailed implementation plan of Vue front-end exporting Excel files
  • Detailed explanation of Excel parsing and exporting based on Vue
  • Pitfalls and solutions when exporting excel using vue

<<:  Manjaro installation CUDA implementation tutorial analysis

>>:  How to choose the format when using binlog in MySQL

Recommend

Problems with nodejs + koa + typescript integration and automatic restart

Table of contents Version Notes Create a project ...

Detailed explanation of this reference and custom properties in JavaScript

Table of contents 1. this keyword 2. Custom attri...

Solution to the problem that Docker container cannot access Jupyter

In this project, the Docker container is used to ...

Examples of two ways to implement a horizontal scroll bar

Preface: During the project development, we encou...

JavaScript imitates Xiaomi carousel effect

This article is a self-written imitation of the X...

You Probably Don’t Need to Use Switch Statements in JavaScript

Table of contents No switch, no complex code bloc...

Basic usage examples of listeners in Vue

Table of contents Preface 1. Basic usage of liste...

Solution to VMware virtual machine no network

Table of contents 1. Problem Description 2. Probl...

Design Association: Why did you look in the wrong place?

I took the bus to work a few days ago. Based on m...

Example analysis of mysql variable usage [system variables, user variables]

This article uses examples to illustrate the usag...

MySQL 5.7.21 installation and configuration tutorial under Window10

This article records the installation and configu...

Implementation of rewrite jump in nginx

1. New and old domain name jump Application scena...