博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
纯前端 vue+ js-xlsx 导入excel表格
阅读量:6069 次
发布时间:2019-06-20

本文共 2054 字,大约阅读时间需要 6 分钟。

<template>
<div class="index">
<input type="file" @change="importFile(this)" id="imFile" style="display: none"
accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet, application/vnd.ms-excel"/>
<Button type="primary" @click="uploadFile">导入</Button>
</div>
</template>
<script>
// 引入xlsx
var XLSX = require("xlsx");
export default {
name: "Index",
data() {
return {
fullscreenLoading: false, // 加载中
imFile: "", // 导入文件el
errorMsg: "", // 错误信息内容
};
},
mounted() {
this.imFile = document.getElementById("imFile");
},
methods: {
uploadFile: function() {
// 点击导入按钮
this.imFile.click();
},
importFile: function() {
// 导入excel
this.fullscreenLoading = true;
let obj = this.imFile;
if (!obj.files) {
this.fullscreenLoading = false;
return;
}
var f = obj.files[0];
var reader = new FileReader();
let $t = this;
reader.onload = function(e) {
var data = e.target.result;
if ($t.rABS) {
$t.wb = XLSX.read(btoa(this.fixdata(data)), {
// 手动转化
type: "base64"
});
} else {
$t.wb = XLSX.read(data, {
type: "binary"
});
}
let json = XLSX.utils.sheet_to_json($t.wb.Sheets[$t.wb.SheetNames[0]]);
$t.dealFile(json); // analyzeData: 解析导入数据
};
if (this.rABS) {
reader.readAsArrayBuffer(f);
} else {
reader.readAsBinaryString(f);
}
},
dealFile: function(data) {
// 处理导入的数据
console.log(data);
this.imFile.value = "";
this.fullscreenLoading = false;
if (data.length <= 0) {
this.errorMsg = "请导入正确信息";
} else {
//导入成功,处理数据
this.$http.post("collector/import", data).then(
function(response) {
if (response.body.status == 1) {
} else {
if (response.body.status == "10101") {
this.$Message.info("未登录");
this.$router.push("/");
}
this.$Message.info(response.body.message);
}
},
function() {}
);
}
},
fixdata: function(data) {
// 文件流转BinaryString
var o = "";
var l = 0;
var w = 10240;
for (; l < data.byteLength / w; ++l) {
o += String.fromCharCode.apply(
null,
new Uint8Array(data.slice(l * w, l * w + w))
);
}
o += String.fromCharCode.apply(null, new Uint8Array(data.slice(l * w)));
return o;
}
}
};
</script>

转载于:https://www.cnblogs.com/weiyuanquyu/p/9811581.html

你可能感兴趣的文章
astah-professional-7_2_0安装
查看>>
函数是对象-有属性有方法
查看>>
uva 10107 - What is the Median?
查看>>
Linux下基本栈溢出攻击【转】
查看>>
c# 连等算式都在做什么
查看>>
使用c:forEach 控制5个换行
查看>>
java web轻量级开发面试教程摘录,java web面试技巧汇总,如何准备Spring MVC方面的面试...
查看>>
根据调试工具看Vue源码之组件通信(一)
查看>>
Thrift RPC 系列教程(5)—— 接口设计篇:struct & enum设计
查看>>
斯坦福-随机图模型-week1.5
查看>>
灵活的运用Model类
查看>>
hadoop 之分布式安装
查看>>
使用ansible工具部署ceph
查看>>
linux系列博文---->深入理解linux启动运行原理(一)
查看>>
Android反编译(一) 之反编译JAVA源码
查看>>
结合当前公司发展情况,技术团队情况,设计一个适合的技术团队绩效考核机制...
查看>>
python-45: opener 的使用
查看>>
cad图纸转换完成的pdf格式模糊应该如何操作?
查看>>
Struts2与Struts1区别
查看>>
网站内容禁止复制解决办法
查看>>