[英]Push an object to an array vue.js
我正在从 excel 获取数据并尝试将该数据保存到数组中。 我想在上传 excel 文件时将对象推送到一个空数组中,但出现此错误Uncaught TypeError: Cannot read properties of undefined (reading 'push')
。 这是我的代码:
<template>
<div id="app">
<input
type="file"
name="xlfile"
id="xlf"
v-on:change="displayFile($event)"
/>
<b-table striped hover bordered :items="itemsList"></b-table>
</div>
</template>
<script>
import * as XLSX from "xlsx/xlsx.mjs";
export default {
name: "App",
data() {
return {
itemsList: [],
};
},
methods: {
displayFile(e) {
var files = e.target.files,
f = files[0];
var reader = new FileReader();
reader.onload = function (e) {
var data = e.target.result;
var workbook = XLSX.read(data, { type: "binary" });
let sheetName = workbook.SheetNames[0];
let worksheet = workbook.Sheets[sheetName];
let rowObject = XLSX.utils.sheet_to_row_object_array(worksheet);
const finalJsonData = JSON.parse(
JSON.stringify(rowObject, undefined, 4)
);
finalJsonData.map((item) => {
this.itemsList.push(...item);
});
//console.log(typeof finalJsonData);
};
reader.readAsArrayBuffer(f);
},
},
};
</script>
解决方案相当简单。 您的itemsList
未定义,因为您的this
不是您期望的(组件对象)。
将您的function
更改为 Arrow function () => {}
。
// reader.onload = function (e) { // delete this line
reader.onload = (e) => { // add this line
var data = e.target.result;
var workbook = XLSX.read(data, { type: "binary" });
let sheetName = workbook.SheetNames[0];
let worksheet = workbook.Sheets[sheetName];
let rowObject = XLSX.utils.sheet_to_row_object_array(worksheet);
const finalJsonData = JSON.parse(
JSON.stringify(rowObject, undefined, 4)
);
finalJsonData.map((item) => {
this.itemsList.push(...item); // now 'this' is your component
});
//console.log(typeof finalJsonData);
};
我建议您阅读function
与箭头函数() => {}
中的绑定
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.