将vue 表格导出为Excel文件

在vue组件中,需要先安装xlsx和file-saver,使用命令如下:

npm install xlsx --save
npm install file-saver --save

在.vue 模板中代码如下

<template>
 <div id="app" >
        <button @click="downloadExl">导出</button>
        <div id="tableId">
            <table class="table table-bordered" style="min-width: 100%;">
                <thead>
                    <tr>
                        <th>#</th>
                        <th v-for="(item,index) in Object.keys(jsonData[0])" :key="index">
                            {{item}}
                        </th>
                    </tr>
                </thead>
                <tbody>
                    <tr v-for="(row,index) in jsonData" :key="index">
                        <th scope="row">{{index}}</th>
                        <td v-for="col in Object.keys(jsonData[0])">{{(row)[col]}}</td>
                    </tr>
                </tbody>
            </table>
        </div>
    </div>
</template>
<script>
var XLSX = require('xlsx')
var FileSaver = require('file-saver')
export default {
        data() {
            return {
                jsonData: [{
                    "姓名": "小杨",
                    "联系电话": "021-33829544",
                    "家庭地址": "浦东新区金桥镇五莲路1706号"
                }]
            }
        },
        methods: {
            downloadExl() {
                let wb = XLSX.utils.table_to_book(document.getElementById('tableId')),
                    wopts = {
                        bookType: 'xlsx',
                        bookSST: false,
                        type: 'binary'
                    },
                    wbout = XLSX.write(wb, wopts);

               FileSaver.saveAs(new Blob([this.s2ab(wbout)], {
                    type: "application/octet-stream;charset=utf-8"
                }), "个人简介表.xlsx");
            },
            s2ab(s) {
                if (typeof ArrayBuffer !== 'undefind') {
                    var buf = new ArrayBuffer(s.length);
                    var view = new Uint8Array(buf);
                    for (var i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
                    return buf;
                } else {
                    var buf = new Array(s.length);
                    for (var i = 0; i != s.length; ++i) buf[i] = s.charCodeAt(i) & 0xFF;
                    return buf;
                }
            }
        }
}
</script>

可以将vue表格中的数据,以excel文件导出。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 转载 :OpenDiggawesome-github-vue 是由OpenDigg整理并维护的Vue相关开源项目库...
    果汁密码阅读 23,375评论 8 124
  • 来源:github.com Vue.js开源项目速查表:https://www.ctolib.com/cheats...
    zhangtaiwei阅读 11,884评论 1 159
  • 秋月夜凉 草芥零星散落 冷涧溪水,拍打,拍打 雕刻了青石 秋风来时 袭一身素色薄衫 长长的摆,浮动,浮动 延续了时长
    墨若雨涵阅读 222评论 0 0
  • .1. 有个小个子 爱上了小胖子 每次见面 酝酿无数次 .2. 小胖子低下头 擦了擦手 眼神荡漾着温柔 ...
    绿子的信阅读 260评论 3 4
  • 一. 前言 最初形成知识管理的观念,是从印象笔记开始的。当时为了写自己的第一篇论文,每看一篇文献,都会把自己的心得...
    圆融Glorio阅读 4,422评论 3 21

友情链接更多精彩内容