当前位置: 首页 > article >正文

vue读取本地excel文件并渲染到列表页面

1.安装插件(版本0.18.5)

npm i xlsx

2.封装插件

<template>
  <div class="container">
    <slot></slot>
  </div>
</template>

<script>
import * as XLSX from 'xlsx'
export default {
  name: 'ReadExcel',
  props: {
    filePath: {
      type: String,
      default: ''
    }
  },
  mounted() {
    this.readExcel()
  },
  methods: {
    readExcel() {
      // 假设你的xlsx文件位于public目录下,并命名为'example.xlsx'
      // console.log('filePath', this.filePath)
      // 使用fetch获取public下的文件
      fetch(this.filePath)
        .then(res => res.arrayBuffer())
        .then(data => {
          // 读取xlsx文件
          const workbook = XLSX.read(data, { type: 'buffer' })
          // 获取第一个工作表
          const firstSheetName = workbook.SheetNames[0]
          const worksheet = workbook.Sheets[firstSheetName]
          // 将工作表转换为JSON
          const tableData = XLSX.utils.sheet_to_json(worksheet)
          this.$emit('getData', tableData)
        })
    }
  }
}
</script>

3.页面使用(filePath文件路径为public下的user.xlsx)

<template>
  <div class="app-container">
    <ReadExcel filePath="/user.xlsx" @getData="getData">
      <el-table :data="tableData" border style="width: 100%">
        <el-table-column align="center" prop="用户编号" label="用户编号" />
        <el-table-column align="center" prop="用户名称" label="用户名称" />
        <el-table-column align="center" prop="用户昵称" label="用户昵称" />
        <el-table-column align="center" prop="部门" label="部门" />
        <el-table-column align="center" prop="手机号码" label="手机号码" />
      </el-table>
      <div class="pagination" style="display: flex; justify-content: flex-end; margin-top: 20px">
        <el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange" :page-sizes="[5, 10, 15, 20]" :page-size="listQuery.pageSize" layout="total, sizes, prev, pager, next, jumper" :total="tableData.length" />
      </div>
    </ReadExcel>
  </div>
</template>

<script>
import ReadExcel from '@/components/ReadExcel'
export default {
  name: 'User',
  components: {
    ReadExcel
  },
  data() {
    return {
      listQuery: {
        pageNum: 1,
        pageSize: 5
      },
      data: []
    }
  },
  computed: {
    tableData() {
      return this.data.slice((this.listQuery.pageNum - 1) * this.listQuery.pageSize, this.listQuery.pageNum * this.listQuery.pageSize)
    }
  },
  methods: {
    getData(val) {
      this.data = val
    },
    handleSizeChange(val) {
      this.listQuery.pageSize = val
    },
    handleCurrentChange(val) {
      this.listQuery.pageNum = val
    }
  }
}
</script>


http://www.kler.cn/a/391254.html

相关文章:

  • Vue中动态样式绑定+CSS变量实现切换明暗主题功能——从入门到进阶
  • 前端Python应用指南(四)Django实战:创建一个简单的博客系统
  • 【再谈设计模式】享元模式~对象共享的优化妙手
  • scala基础学习_运算符
  • 深度学习在自动驾驶车辆车道检测中的应用
  • 依图科技简介
  • 低代码开发
  • Tofu AI视频处理模块视频输入配置方法
  • LeetCode 热题100 之 多维动态规划
  • 在 Flutter 应用中调用后端接口的方法
  • Linux高阶——1109—线程函数线程属性线程分类
  • 【缓存策略】你知道 Write Around(缓存绕过写)这个缓存策略吗?
  • SQL Servers审核提高数据库安全性
  • 机器学习day1-数据集
  • Ubuntu23.10下解决C语言调用mysql.h问题
  • arcgis for js实现FeatureLayer图层弹窗展示所有field字段
  • Matlab自学笔记四十一:介绍日期时间型的显示格式:年‘y‘ 月‘M‘ 日‘d‘ 周‘e‘ 时‘h‘ 分‘m‘ 秒‘s‘
  • 科研绘图系列:R语言差异分析双侧柱状图(grouped barplot)
  • PostgreSQL 表文件损坏异常
  • vue的样式知识点
  • 【Windows】任务管理器无法解决的问题?试试`tasklist`和`taskkill`命令
  • IOS开发之Xcode版本选择
  • POI实现根据PPTX模板渲染PPT
  • 攻防世界38-FlatScience-CTFWeb
  • 【Linux】:进程信号(信号概念 信号处理 信号产生)
  • SpringBoot框架的企业资产管理自动化