背景

前端点击导出excel按钮后,请求完需要导出的数据后发送给主进程electron,由主进程保存到本地

dialog

显示用于打开和保存文件、警报等的本机系统对话框。

dialog 模块提供了api来展示原生的系统对话框,例如打开文件框,alert框,所以web应用可以给用户带来跟系统应用相同的体验.

let win = ...;  // BrowserWindow in which to show the dialog
const dialog = require('electron').dialog;
console.log(dialog.showOpenDialog({ properties: [ 'openFile', 'openDirectory', 'multiSelections' ]}));

前端代码(渲染进程)

// 引入ipcRenderer模块
const { ipcRenderer } = require('electron')
// 表格数据拟定为 data
let excelModel = new Blob([data], { type: "application/octet-stream" })

不知道 Blob 是什么的点击这里

// 创建一个FileReader的实例
let reader = new FileReader()
// 开始读取指定的Blob中的内容。一旦完成,result属性中将包含一个data: URL格式的Base64字符串以表示所读取文件的内容。
reader.readAsDataURL(excelModel)
// 处理 load 事件。该事件在读取操作完成时触发
reader.addEventListener("loadend", function() {
// reader.result 包含被转化为类型数组 typed array 的 blob
// 向主进程发送下载excel消息
ipcRenderer.send("saveDialog", {
baseCode: reader.result,
fileType: 'excel',
fileName: '封神榜'
})
// 接收主进程发送回来的下载成功回调
ipcRenderer.once('succeedDialog', event => {
// 成功回调
})
// 接收主进程发送回来的下载失败回调
ipcRenderer.once('defeatedDialog', event => {
// 失败回调
}) })

不知道 FileReader 是什么的点击这里

electron代码(主进程)

// 创建BrowserWindow实例
let win = new BrowserWindow(browser)
// 引入dialog、ipcMain、fs模块
const { dialog, ipcMain } = require('electron')
const fs = require('fs')
// 定义文件下载扩展名选择
const extensionType = {
// 图片
images: [
{ name: '.jpg', extensions: ['jpg'] },
{ name: '.png', extensions: ['png'] },
{ name: '.gif', extensions: ['gif'] },
],
// Excel
excel: [
{ name: '.xlsx', extensions: ['xlsx'] },
{ name: '.xls', extensions: ['xls'] },
]
}
//在主线程下,通过ipcMain对象监听渲染线程传过来的saveDialog事件
ipcMain.on('saveDialog', (event, arg) => {
// 打开弹窗
dialog.showSaveDialog(win, {
// 在 Windows 和 Linux 上, 打开对话框不能同时是文件选择器和目录选择器, 因此如果在这些平台上将 properties 设置为["openFile"、"openDirectory"], 则将显示为目录选择器。
properties: ['openFile', 'openDirectory'],
// 默认情况下使用的绝对目录路径、绝对文件路径、文件名
defaultPath: arg.fileName,
// 文件下载扩展名
filters: [
...extensionType[arg.fileType]
],
// 点击保存回调
}, filePath =>{
// filePath存在则为保存路径 否为undefined
// 去掉头部无用字段并将base64转码成buffer
let dataBuffer = Buffer.from(arg.baseCode.split('base64,')[1], 'base64')
// 检测文件扩展名是否正确
let typeFlag = extensionType[arg.fileType].some(item => {
if(filePath) {
return item.extensions[0] === filePath.substring(filePath.lastIndexOf('.') + 1)
} else {
return false
}
})
if(typeFlag){
fs.writeFile(filePath, dataBuffer, err => {
// 失败
if (err) {
// 向渲染进程发送消息通知失败
win.webContents.send('defeatedDialog')
}
})
// 成功 向渲染进程发送消息通知成功
win.webContents.send('succeedDialog')
// 判断是否存在保存路径
} else if(filePath !== undefined){
dialog.showMessageBox({
type: 'error',
title: '系统提示',
message: '系统检测出文件类型异常,请检查并重新选择或填写'
})
}
})
})

之所以在确定后再次对文件的扩展名进行判断,是因为传入excel的文件扩展名仍然可以保存其他扩展名,如.jpg,具体原因作者也不太清楚>﹏<,以后知道后会更新的。。。

以上仅供参考,如有问题欢迎指出,但我不一定改(~ ̄▽ ̄)~

文章原创 转载附带原创链接

参考

electron-dialog

electron中recorderJs导出blob对象,并使用node保存到本地

electron——dialog(实现导出excel)的更多相关文章

  1. NPOI、MyXls、Aspose.Cells 导入导出Excel(转)

    Excel导入及导出问题产生: 从接触.net到现在一直在维护一个DataTable导s出到Excel的类,时不时还会维护一个导入类.以下是时不时就会出现的问题: 导出问题: 如果是asp.net,你 ...

  2. DataGridView如何快速导出Excel

    从DataGridView或DataTable导出Excel文件,为了按照数据类型设置单元格格式,导出Excel时速度都比较慢,一直找不到好的办法. 最后从外文网站上找到解决办法,使用ws.get_R ...

  3. asp.net mvc4 easyui datagrid 增删改查分页 导出 先上传后导入 NPOI批量导入 导出EXCEL

    效果图 数据库代码 create database CardManage use CardManage create table CardManage ( ID ,) primary key, use ...

  4. Java使用POI导出excel(下)——实例与小技巧

    [更新]:thinkgem的导出工具类: /** * Copyright © 2012-2016 <a href="https://github.com/thinkgem/jeesit ...

  5. 选择性导出excel表中内容

    package com.huawei.utils; import java.io.FileNotFoundException;import java.io.FileOutputStream;impor ...

  6. 网页表格导入导出Excel

    用JS实现网页表格数据导入导出excel. 首先是JS文件中的代码 (function($){ function getRows(target){ var state = $(target).data ...

  7. Java web项目 上传图片保存到数据库,并且查看图片,(从eclipse上移动到tomact服务器上,之路径更改,包括显示图片和导出excel)

    //项目做完之后,在本机电脑运行完全正常,上传图片,显示图片,导出excel,读取excel等功能,没有任何问题,但是,当打成war包放到服务器上时,这些功能全部不能正常使用. 最大的原因就是,本机测 ...

  8. C#使用Aspose.Cells导出Excel简单实现

    首先,需要添加引用Aspose.Cells.dll,官网下载地址:http://downloads.aspose.com/cells/net 将DataTable导出Xlsx格式的文件下载(网页输出) ...

  9. 利用poi导出Excel

    import java.lang.reflect.Field;import java.lang.reflect.InvocationTargetException;import java.lang.r ...

随机推荐

  1. ESP8266开发之旅 网络篇① 认识一下Arduino Core For ESP8266

        博主的 ESP8266开发之旅 专栏主要分为三个部分: 基础篇 网络篇 应用篇     从这一篇开始,博主将会带领各位读者在基础篇的基础上进入网络的世界.在此,博主认为各位读者已经具备以下前提 ...

  2. jquery获取dom属性方法

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  3. SpringCloud之Nacos服务发现(十七)

    一 Nacos简介 Nacos是以服务为主要服务对象的中间件,Nacos支持所有主流的服务发现.配置和管理. Nacos主要提供以下四大功能: 服务发现与服务健康检查 Nacos使服务更容易注册自己并 ...

  4. Spring中@Resource注解报错

    描述:Spring框架中,@Resource注解报错,在书写时没有自动提示 解决方法:因为maven配置文件的pom.xml文件中缺少javax.annotation的依赖,在pom.项目路中加入依赖 ...

  5. Flask源码分析二:路由内部实现原理

    前言 Flask是目前为止我最喜欢的一个Python Web框架了,为了更好的掌握其内部实现机制,这两天准备学习下Flask的源码,将由浅入深跟大家分享下,其中Flask版本为1.1.1. 上次了解了 ...

  6. 说说 Python3 中的数字处理

    最近在处理订单相关的问题,踩了数字的一些坑,在此记录下. 其中有问题的代码涉及金额比较,便于描述,假设了下面一段代码 def is_paid(pay_price, paid_price): retur ...

  7. Luogu P1098 字符串的展开

    这几天划了划水看了看初赛的试题,没写什么随笔. 今天刷刷洛谷试炼场.(不要问为什么我还在普及区) 题目描述 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串 ...

  8. 使用Typescript重构axios(十五)——默认配置

    0. 系列文章 1.使用Typescript重构axios(一)--写在最前面 2.使用Typescript重构axios(二)--项目起手,跑通流程 3.使用Typescript重构axios(三) ...

  9. CSS(4)---三大特性(继承性,层叠性,优先级)

    CSS(4)---三大特性(继承性,层叠性,优先级) CSS有三大特性分别是: 继承性,层叠性,优先级. 一.继承性 概念 给父元素设置一些属性,子元素也可以使用,这个我们就称之为继承性. 注意 1. ...

  10. 生活问题 | 对华为畅玩手机5X进行升级

    步骤一:准备一张SD卡,建议使用Sandisk, Kingstone, 或Kingmax,大小建议在2G KIW-AL10C00B258 软件版本升级指导书 Secret  2016-11-25 Hu ...