SpreadVue实现内置excel在线编辑并保存为后端可以接受的json格式

SpreadVue实现内置excel在线编辑并保存为后端可以接受的json格式

  • 一、定义excel模板
    • [1.1 用speadVue默认例子,直接在线编辑模板,并绑定工作表](#1.1 用speadVue默认例子,直接在线编辑模板,并绑定工作表)
    • [1.2 下载模板excel文件,补充行的公式,并锁定公式不允许编辑](#1.2 下载模板excel文件,补充行的公式,并锁定公式不允许编辑)
  • 二、实际使用
    • [2.1 初始化刚才保存的excel模板文件](#2.1 初始化刚才保存的excel模板文件)
    • [2.2 在录入数据后保存数据](#2.2 在录入数据后保存数据)

项目背景:需要在线录入部分数据,其他行数据由特定公式计算,且公式不可编辑,用于存在很多行公式,通过前端JS计算非常不方便,且公式一改js要变动的很多,所以这时候推荐使用SpreadVue内置excel

一、定义excel模板

1.1 用speadVue默认例子,直接在线编辑模板,并绑定工作表

1.2 下载模板excel文件,补充行的公式,并锁定公式不允许编辑

二、实际使用

2.1 初始化刚才保存的excel模板文件

java 复制代码
var xhr = new XMLHttpRequest();
xhr.open('GET', url, true);//这里url是文件请求地址
xhr.responseType = 'blob';
xhr.onload = function (e) {
    if (this.status == 200) {
        var blob = this.response;
        var fd = new FormData();
        fd.append("file", [blob]);
        var fd = new File([blob],  "文件名.xlsx");
        Spread.import(fd, function () {
        }, function () { }, openOptions);
    }
};
xhr.send();

2.2 在录入数据后保存数据

java 复制代码
var Spread = designer.getWorkbook();
 var sheetid = 0;
 var sheet = Spread.getSheet(sheetid);
 var table = sheet.tables.all()[0]
 var range = table.range();
 var mm = sheet.getArray(range.row, range.col, 1, range.colCount)[0];//列字段field
 var gg = sheet.getArray(range.row + 1, range.col, range.rowCount, range.colCount);//行数据
 var datalist = new Array();
 var object = {};
 for (var j = 0; j < gg.length; j++) {
     var object = new Object();
     for (var n = 0; n < mm.length; n++) {
         object[mm[n]] = gg[j][n];
     }
     datalist.push(object);
 }
 // console.log(datalist,'datalist')//最终传递给服务器的数据
相关推荐
njsgcs8 小时前
读取文件夹内的pdf装换成npg给vlm分类人工确认然后填入excel vlmapi速度挺快 qwen3-vl-plus webbrowser.open
分类·pdf·excel
星空的资源小屋8 小时前
Tuesday JS,一款可视化小说编辑器
运维·网络·人工智能·编辑器·电脑·excel
sinat_375112269 小时前
abap 通用发送邮件程序(获取alv数据,带excel附件)
excel·sap·abap·邮件
忘忧记9 小时前
Excel拆分和合并优化版本
windows·microsoft·excel
牵牛老人10 小时前
Qt 中如何操作 Excel 表格:主流开源库说明介绍与 QXlsx 库应用全解析
qt·开源·excel
十碗饭吃不饱10 小时前
RuoYi/ExcelUtil修改(导入excel表时,表中字段没有映射上数据库表字段)
数据库·windows·excel
林月明20 小时前
【VBA】自动设置excel目标列的左邻列格式
开发语言·excel·vba·格式
JavaOpsPro1 天前
审计 jenkins获取构建历史,生成excel
运维·jenkins·excel
CodeCraft Studio1 天前
国产化Excel开发组件Spire.XLS教程:在Python中将Pandas DataFrame导出到Excel的详细教程
python·excel·pandas
电话交换机IPPBX-3CX1 天前
在 MS Excel 和 Google Sheets 中生成 3CX 可视化通话报告
excel·ip pbx·电话交换机·google表格·可视化报表