html和vue XLSX.utils.json_to_sheet导出excel模板-程序员宅基地

技术标签: vue  

html XLSX.utils.json_to_sheet导出excel模板,由于此处是函数自调用,所以页面加载的时候就会提示下载

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>展示 用xlsx库 导出excel,含多个sheet</title>
  </head>
  <body>
    <h1>展示 用xlsx库 导出excel,含多个sheet</h1>

    <button id="export" style="padding:20px;background: #69f;color:#fff;" @click="aaa()"> 导出excel</button>
   
    <script src="https://unpkg.com/xlsx/dist/xlsx.core.min.js"></script>
	
    <script>
      // 将workbook装化成blob对象
     function workbook2blob(workbook) {
    
         // 生成excel的配置项
         var wopts = {
    
             // 要生成的文件类型
             bookType: "xlsx",
             // // 是否生成Shared String Table,官方解释是,如果开启生成速度会下降,但在低版本IOS设备上有更好的兼容性
             bookSST: false,
             type: "binary"
         };
         var wbout = XLSX.write(workbook, wopts);
         // 将字符串转ArrayBuffer
        
         var blob = new Blob([s2ab(wbout)], {
    
             type: "application/octet-stream"
         });
         return blob;
     }
     function s2ab(s) {
    
         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;
     }
         // 将blob对象创建bloburl,然后用a标签实现弹出下载框
     function openDownloadDialog(blob, fileName) {
    
         if (typeof blob == "object" && blob instanceof Blob) {
    
             blob = URL.createObjectURL(blob); // 创建blob地址
         }
         var aLink = document.createElement("a");
         aLink.href = blob;
         // HTML5新增的属性,指定保存文件名,可以不要后缀,注意,有时候 file:///模式下不会生效
         aLink.download = fileName || "";
         var event;
         if (window.MouseEvent) event = new MouseEvent("click");
         //   移动端
         else {
    
             event = document.createEvent("MouseEvents");
             event.initMouseEvent( "click", true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null );
         }
         aLink.dispatchEvent(event);
     }
     // 用的例子
     let sheet1data = [ {
     department: "行政部", count: 2 }, {
     department: "前端部", count: 2 } ];
     let sheet2data = [ {
     name: "张三", do: "整理文件" }, {
     name: "李四", do: "打印" } ];
     let sheet3data = [ {
     name: "张大人", do: "vue" }, {
     name: "李大人", do: "react" } ];
     var sheet1 = XLSX.utils.json_to_sheet(sheet1data);
     var sheet2 = XLSX.utils.json_to_sheet(sheet2data);
     var sheet3 = XLSX.utils.json_to_sheet(sheet3data);
     
     /* create a new blank workbook */
     var wb = XLSX.utils.book_new();
     XLSX.utils.book_append_sheet(wb, sheet1, "部门统计");
     XLSX.utils.book_append_sheet(wb, sheet2, "行政部");
     XLSX.utils.book_append_sheet(wb, sheet3, "前端部");
     const workbookBlob = workbook2blob(wb);
    openDownloadDialog(workbookBlob, `部门统计.xlsx`);

    </script>
  </body>
</html>

下面是vue,自己总结的

//找一个位置添加此按钮
<Button icon="ios-download-outline" type="primary" @click="exportData">模板导出</Button>

//此处是js
 changeData (s) {
    
      //如果存在ArrayBuffer对象(es6) 最好采用该对象
      if (typeof ArrayBuffer !== 'undefined') {
    
        //1、创建一个字节长度为s.length的内存区域
        var buf = new ArrayBuffer(s.length);
        //2、创建一个指向buf的Unit8视图,开始于字节0,直到缓冲区的末尾
        var view = new Uint8Array(buf);
        //3、返回指定位置的字符的Unicode编码
        for (var i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;
        return buf;
      } else {
    
        var buf2 = new Array(s.length);
        for (var k = 0; k != s.length; ++k) buf2[k] = s.charCodeAt(k) & 0xFF;
        return buf2;
      }
    },
    saveAs (obj, fileName) {
    //当然可以自定义简单的下载文件实现方式
      var tmpa = document.createElement("a");
      tmpa.download = fileName ? fileName + '.xlsx' : new Date().getTime() + '.xlsx';
      tmpa.href = URL.createObjectURL(obj); //绑定a标签
      tmpa.click(); //模拟点击实现下载

      setTimeout(function () {
     //延时释放
        URL.revokeObjectURL(obj); //用URL.revokeObjectURL()来释放这个object URL
      }, 100);

    },
    //按钮调用的方法
    exportData () {
    
      var wopts = {
    
        bookType: 'xlsx',
        bookSST: false,
        type: 'binary'
      };
      var workBook = {
    
        SheetNames: ['Sheet1'],
        Sheets: {
    },
        Props: {
    }
      };
	//设置excel表格的表头
      let sheet1data = [{
     "销售物料代码": "", "采购物料代码": "", "下单数量": "" }]
      //1、XLSX.utils.json_to_sheet(data) 接收一个对象数组并返回一个基于对象关键字自动生成的“标题”的工作表,默认的列顺序由使用Object.keys的字段的第一次出现确定
      //2、将数据放入对象workBook的Sheets中等待输出
      workBook.Sheets['Sheet1'] = XLSX.utils.json_to_sheet(sheet1data)

      //3、XLSX.write() 开始编写Excel表格
      //4、changeData() 将数据处理成需要输出的格式
      this.saveAs(new Blob([this.changeData(XLSX.write(workBook, wopts))], {
     type: 'application/octet-stream' }))
    },
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/youtiantin/article/details/118896207

智能推荐

sk_buf, 再转载,太经典了 - 网络协议栈分析 - 草本植物_skbuf-程序员宅基地

文章浏览阅读4k次。本文转自: http://www.360doc.com/content/09/0205/16/36491_2466152.shtml#sk_buff结构可能是linux网络代码中最重要的数据结构,它表示接收或发送数据包的包头信息。它在中定义,并包含很多成员变量供网络代码中的各子系统使用。这个结构在linux内核的发展过程中改动过很多次,或者是增加新的选项,或者是重新组织已存在的_skbuf

怎么批量在数字里加入网页_手把手教你爬取天堂网1920*1080大图片(批量下载)——理论篇-程序员宅基地

文章浏览阅读1.2k次。/1 前言/平时我们要下载图片,要要一个一个点击下载是不是觉得很麻烦?那有没有更加简便的方法呢?答案是肯定的,这里我们以天堂网为例,批量下载天堂网的图片。/2 项目准备工作/首先 我们第一步我们要安装一个pycham的软件。可以参考这篇文章:Python环境搭建—安利Python小白的Python和Pycharm安装详细教程。天堂网的网址:https://www.ivsky.com/bizhi/1...

传奇假人自动上线_传奇商业脚本 各种M2防假人脚本大集合 传奇私服脚本-程序员宅基地

文章浏览阅读4.9k次。各种M2防假人脚本大集合BLUE的M2防假人攻击脚本:首先先在D:\MirServer\Mir200\Envir\QuestDiary\数据文件 目录下建一个“激活.txt”文本文挡其次在D:\MirServer\Mir200\Envir\MapQuest_def 目录下的QManage.txt脚本里加上如下一段[@Login]#ifchecknamelist ..\QuestDiary\数据文件..._传奇防挂机流星验证

系统工程的本质_为什么要强调系统工程-程序员宅基地

文章浏览阅读2.6k次,点赞3次,收藏15次。原文链接:https://mp.weixin.qq.com/s/9uTG1QyjOzIfeMuvioNkWw 工程,是日常生活和工作时经常使用的一个词语,例如土木工程、电子工程、机械工程、系统工程,以及法制工程、希望工程、菜篮子工程;也有三峡工程、载人航天工程、探月工程等;还有“创新是一项系统工程”“改革是一项系统工程”等说法。这个词语本身并没有令人费解的地方,但在不同的语境中,却体现出迥..._为什么要强调系统工程

TensorFlow里,shape=(?, 120)里的问号是怎么回事呢_tf shape为什么有问号-程序员宅基地

文章浏览阅读4.1k次。TensorFlow里,shape=(?, 120)里的问号是怎么回事呢125self.cos_sim(1024,51)Tensor("cosine-imilarity-layer/mul_2:0",shape=(1024,51),dtype=float32)126type(self.query_batch):<class'tensorflow...._tf shape为什么有问号

[RK3568 Android11] 开发之调试RK809 codec音频-SPK喇叭_rk3568 喇叭左右声道问题-程序员宅基地

文章浏览阅读5.5k次,点赞2次,收藏10次。目录前言一、注册声卡顺序二、SPK喇叭路由配置三、tinyalsa调试工具前言瑞芯微RK809是一种复杂的功率管理集成电路(PMIC)集成编解码器,适用于由外部电源供电的多核系统应用;同时它也集成了音频编解码器,这样在硬件设计上可以直接使用RK809 codec功能,不必再外挂个其他codec芯片;RK809 codec不仅支持SPK,还支持耳机,MIC功能;一、注册声卡顺序设备树dts里面原厂帮我们配置好了rk809_sound,我们直接..._rk3568 喇叭左右声道问题

随便推点

人工智能城市和智慧城市_智慧城市:人工智能在城市管理中的应用-程序员宅基地

文章浏览阅读4.9k次。人工智能城市和智慧城市Smart cities aren’t just sci-fi or cyberpunk dreams, but an actual solution based on Artificial Intelligence and the Internet of Things. But the question is, what is the mechanism that put ..._intelligent edge computing based on machine learning for smart city

[React-Native]样式和布局_reactnative内联样式怎么用-程序员宅基地

文章浏览阅读1.2w次。一、基本样式(1)内联样式 在组件里面定义样式 小字号内联样式(2)外联样式 在组件里指向外面的样式 大字号外联样式(3)样式具有覆盖性 如果定义相同属性的样式,后面会覆盖_reactnative内联样式怎么用

CH340串口转USB驱动安装-程序员宅基地

文章浏览阅读963次。驱动下载指南_串口转usb驱动

杰里之.V006 音箱版本删除录音文件,需要优化 system.a 库【篇】_ac6965a电路图-程序员宅基地

文章浏览阅读139次。// folder : /xxxxxx // filename : xxxx0000.yyy u8 file_api_delete_file(const char *path, const char *folder, const char *filename, u32 *file_index)_ac6965a电路图

教大家如何去看开源项目_开源项目哪里找-程序员宅基地

文章浏览阅读2.2k次,点赞2次,收藏10次。如何去看开源项目_开源项目哪里找

Linux 硬件时间(RTC time)、系统时间(UTC时间、Universal time)、本地时间(Local time)、时区(Time zone)与夏令时(DST)解析-程序员宅基地

文章浏览阅读8.3k次,点赞8次,收藏34次。硬件时间,也被称为实时时钟(RTC),是指计算机主板上的一个独立于操作系统的设备,它在电源关闭甚至断电情况下也能保持运行。其功能是记录当前的日期和时间。系统时间是计算机内部使用的时间,它通常在启动时从RTC设置,然后由系统时钟进行跟踪。系统时钟是操作系统内核的一部分,可以以毫秒或纳秒级别提供精确时间。本地时间是系统时间经过时区转换后的时间。时区是根据地理位置确定的,全球分为24个时区,每个时区大约代表15度的经度。例如,北京时间是UTC+8,而伦敦时间是UTC+0。时区是为了方便统一时间而划分的地理区域。_rtc time

推荐文章

热门文章

相关标签