Home Web Front-end Vue.js Efficient interaction between Vue and Excel: how to achieve batch filling and import of data

Efficient interaction between Vue and Excel: how to achieve batch filling and import of data

Jul 21, 2023 am 10:59 AM
vue excel Batch fill

Efficient interaction between Vue and Excel: How to implement batch filling and importing of data

In most projects, batch filling and importing of data is a common requirement. As a popular data processing tool, Excel, combined with the Vue framework, can achieve efficient data interaction. This article will introduce how to batch fill and import data through Vue and some commonly used plug-ins, and provide code examples.

  1. Use the vue-xlsx plug-in to read and write Excel files
    vue-xlsx is a Vue component based on the js-xlsx plug-in, which allows us to directly read and write Excel files through Vue . We can use the following command to install vue-xlsx:
npm install vue-xlsx -S
Copy after login

Then, introduce vue-xlsx in the main.js file of the Vue project:

import VueXlsx from 'vue-xlsx'
Vue.use(VueXlsx)
Copy after login
  1. to achieve data batching Fill function
    Assume we have an Excel file containing student names and grades, we can achieve batch filling of data through the following code:
<template>
  <div>
    <input type="file" @change="handleFileUpload" />
    <table>
      <thead>
        <tr>
          <th>学生姓名</th>
          <th>成绩</th>
        </tr>
      </thead>
      <tbody>
        <tr v-for="(student, index) in students" :key="index">
          <td>{{ student.name }}</td>
          <td>{{ student.score }}</td>
        </tr>
      </tbody>
    </table>
  </div>
</template>

<script>
export default {
  data() {
    return {
      students: []
    }
  },
  methods: {
    handleFileUpload(event) {
      this.students = []
      const file = event.target.files[0]
      const reader = new FileReader()

      reader.onload = (e) => {
        const data = new Uint8Array(e.target.result)
        const workbook = this.$xlsx.read(data, { type: 'array' })
        const sheetName = workbook.SheetNames[0]
        const worksheet = workbook.Sheets[sheetName]
        const jsonData = this.$xlsx.utils.sheet_to_json(worksheet, { header: 1 })

        jsonData.forEach((row, index) => {
          if (index !== 0) {
            const student = { name: row[0], score: row[1] }
            this.students.push(student)
          }
        })
      }

      reader.readAsArrayBuffer(file)
    }
  }
}
</script>
Copy after login

In the above code, we first add in the template An input tag for file upload and listens for the change event. When the user selects the Excel file, the file will be read and the handleFileUpload method will be triggered.

In the method, first clear this.students, and then use FileReader to read the file content. After the reading is completed, use the this.$xlsx object of vue-xlsx to parse the file content, and convert the data in Excel to JSON format through the this.$xlsx.utils.sheet_to_json method.

Finally, we convert the JSON data line by line into student objects and add them to this.students array. Use the v-for instruction in the template to traverse the array and display student names and grades.

  1. Implement the data import function
    In addition to batch filling, we can also implement the data import function to import data in Excel into a form or database in Vue. The following is a simple example:
<template>
  <div>
    <input type="file" @change="handleFileUpload" />
    <form>
      <div>
        <label>学生姓名:</label>
        <input v-model="student.name" />
      </div>
      <div>
        <label>成绩:</label>
        <input v-model="student.score" />
      </div>
      <button @click="importData">导入数据</button>
    </form>
  </div>
</template>

<script>
export default {
  data() {
    return {
      student: {}
    }
  },
  methods: {
    handleFileUpload(event) {
      const file = event.target.files[0]
      const reader = new FileReader()

      reader.onload = (e) => {
        const data = new Uint8Array(e.target.result)
        const workbook = this.$xlsx.read(data, { type: 'array' })
        const sheetName = workbook.SheetNames[0]
        const worksheet = workbook.Sheets[sheetName]
        const jsonData = this.$xlsx.utils.sheet_to_json(worksheet, { header: 1 })

        if (jsonData.length > 0) {
          const row = jsonData[1]
          this.student = { name: row[0], score: row[1] }
        }
      }

      reader.readAsArrayBuffer(file)
    },
    importData() {
      // 将this.student中的数据导入表单或数据库
    }
  }
}
</script>
Copy after login

In the above code, we use a form to display the data to be imported. The form contains input boxes for student names and grades. When the user selects the Excel file, the file content is parsed in the same way, and the first row of data is used as the imported data.

Users can modify the data in the input box, then click the "Import Data" button and execute the importData method to import the data in this.student into the form or database.

Through the above code examples, we can see the efficient interaction between Vue and Excel. Whether it is batch filling or data import, using Vue and vue-xlsx plug-in can simplify the development process and improve work efficiency.

Summary
This article introduces how to implement batch filling and import of data through Vue and vue-xlsx plug-in. By correctly installing and using the vue-xlsx plug-in, we can easily read and write Excel files and use it with the Vue framework. Whether it is for data management or data import needs, such efficient interaction can greatly improve development efficiency.

The above is the detailed content of Efficient interaction between Vue and Excel: how to achieve batch filling and import of data. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1652
14
PHP Tutorial
1251
29
C# Tutorial
1224
24
How to use bootstrap in vue How to use bootstrap in vue Apr 07, 2025 pm 11:33 PM

Using Bootstrap in Vue.js is divided into five steps: Install Bootstrap. Import Bootstrap in main.js. Use the Bootstrap component directly in the template. Optional: Custom style. Optional: Use plug-ins.

How to add functions to buttons for vue How to add functions to buttons for vue Apr 08, 2025 am 08:51 AM

You can add a function to the Vue button by binding the button in the HTML template to a method. Define the method and write function logic in the Vue instance.

How to use watch in vue How to use watch in vue Apr 07, 2025 pm 11:36 PM

The watch option in Vue.js allows developers to listen for changes in specific data. When the data changes, watch triggers a callback function to perform update views or other tasks. Its configuration options include immediate, which specifies whether to execute a callback immediately, and deep, which specifies whether to recursively listen to changes to objects or arrays.

What does vue multi-page development mean? What does vue multi-page development mean? Apr 07, 2025 pm 11:57 PM

Vue multi-page development is a way to build applications using the Vue.js framework, where the application is divided into separate pages: Code Maintenance: Splitting the application into multiple pages can make the code easier to manage and maintain. Modularity: Each page can be used as a separate module for easy reuse and replacement. Simple routing: Navigation between pages can be managed through simple routing configuration. SEO Optimization: Each page has its own URL, which helps SEO.

How to return to previous page by vue How to return to previous page by vue Apr 07, 2025 pm 11:30 PM

Vue.js has four methods to return to the previous page: $router.go(-1)$router.back() uses &lt;router-link to=&quot;/&quot; component window.history.back(), and the method selection depends on the scene.

How to reference js file with vue.js How to reference js file with vue.js Apr 07, 2025 pm 11:27 PM

There are three ways to refer to JS files in Vue.js: directly specify the path using the &lt;script&gt; tag;; dynamic import using the mounted() lifecycle hook; and importing through the Vuex state management library.

How to use vue traversal How to use vue traversal Apr 07, 2025 pm 11:48 PM

There are three common methods for Vue.js to traverse arrays and objects: the v-for directive is used to traverse each element and render templates; the v-bind directive can be used with v-for to dynamically set attribute values ​​for each element; and the .map method can convert array elements into new arrays.

How to jump to the div of vue How to jump to the div of vue Apr 08, 2025 am 09:18 AM

There are two ways to jump div elements in Vue: use Vue Router and add router-link component. Add the @click event listener and call this.$router.push() method to jump.

See all articles