感谢mkysoft 和this 的回答。我能够读取 .xlsx 文件内容。
为此,我必须在我的项目中创建两个文件 jszip.js 和 xlsx.js。我为它们创建了一个单独的文件夹,并在我的控制器的sap.ui.define 部分中提到了这两个文件的位置。
这两个库可在
CDNJS - JSZip3 和
CDNJS - XLSX4 位置。
sap.ui.define([
"sap/ui/core/mvc/Controller",
.... //other libraries
"projectnamespace/foldername/jszip",
"projectnamespace/foldername/xlsx"
], function (Controller,...., jszip, xlsx)
然后,为了读取.xlsx 文件,我添加了以下代码:
var oFileUploader = sap.ui.getCore().byId("fileUploader"); // get the sap.ui.unified.FileUploader
var file = oFileUploader.getFocusDomRef().files[0]; // get the file from the FileUploader control
if (file && window.FileReader) {
var reader = new FileReader();
reader.onload = function (e) {
var data = e.target.result;
var excelsheet = XLSX.read(data, {
type: "binary"
});
excelsheet.SheetNames.forEach(function (sheetName) {
var oExcelRow = XLSX.utils.sheet_to_row_object_array(excelsheet.Sheets[sheetName]); // this is the required data in Object format
var sJSONData = JSON.stringify(oExcelRow); // this is the required data in String format
});
};
reader.readAsBinaryString(file);
}