Я использую xlsx.core.min.js для загрузки файлов Excel в SP и передачи их содержимого в новый список.У меня он работает в Edge, но он не будет работать в IE 11.
Первая консольная ошибка, которую я получил, была "Объект не поддерживает свойство или метод 'charCodeAt'"
Я прочитал о проблемах совместимости с .readAsArrayBuffer () и заменил его.Затем я начал получать сообщение об ошибке «Объект не поддерживает свойство или метод« readAsBinaryString »»
** Примечание: использование только .readAsArrayBuffer () привело к исходной консольной ошибке charCodeAt**
Как мне заставить этот код работать?Заранее спасибо!
function ExportToTable() {
var regex = /^([a-zA-Z0-9\s_\\.\-:])+(.xlsx|.xls)$/;
/*Checks whether the file is a valid excel file*/
if (regex.test($("#excelfile").val().toLowerCase())) {
var xlsxflag = false;
/*Flag for checking whether excel is .xls format or .xlsx format*/
if ($("#excelfile").val().toLowerCase().indexOf(".xlsx") > 0) {
xlsxflag = true;
}
/*Checks whether the browser supports HTML5*/
if (typeof (FileReader) != "undefined") {
var reader = new FileReader();
reader.onload = function (e) {
var data = e.target.result;
/*Converts the excel data in to object*/
if (xlsxflag) {
var workbook = XLSX.read(data, { type: 'binary' });
}
else {
var workbook = XLS.read(data, { type: 'binary' });
}
/*Gets all the sheetnames of excel in to a variable*/
var sheet_name_list = workbook.SheetNames;
var cnt = 0; /*This is used for restricting the script to consider only first sheet of excel*/
sheet_name_list.forEach(function (y) { /*Iterate through all sheets*/
/*Convert the cell value to Json*/
if (xlsxflag) {
var exceljson = XLSX.utils.sheet_to_json(workbook.Sheets[y]);
}
else {
var exceljson = XLS.utils.sheet_to_row_object_array(workbook.Sheets[y]);
}
//alert (exceljson.length + " ----" + cnt);
if (exceljson.length > 0 && cnt == 0) {
BindTable(exceljson, '#exceltable');
cnt++;
}
});
$('#exceltable').show();
}
if (xlsxflag) {/*If excel file is .xlsx extension than creates a Array Buffer from excel*/
reader.readAsArrayBuffer($("#excelfile")[0].files[0]);
}
else {
reader.readAsBinaryString($("#excelfile")[0].files[0]);
}
}
else {
// alert("Sorry! Your browser does not support HTML5!");
}
}
else {
// alert("Please upload a valid Excel file!");
}
}