B. *_*red 8 javascript ajax jquery
我正在将JavaScript添加到SharePoint中,并且试图编写一个从库中获取Excel文档或其中数据的函数。我已经找到了解决方法,但是有问题的文件太大而无法返回。我已经考虑过手动设置ajax的大小限制,但是我没有找到任何方法来执行此操作,因此计划B是针对每一行发送查询
$("#button").click(function() {
readFileRow(libraryUrl, "FileName.xlsx", "Sheet1", 1, "E", [])
.done(function(cells) {
console.log(xmlToJson(cells.documentElement));
});
});
/**
* Reads a file in SharePoint Library via ExcelRest and returns the document
*
* @params string libraryUrl
* @params string fileName
* @params string sheetName
* @params int rowNum
* @params string lastColumn
* @params string[][] finalResults
*
* @returns string[][]
**/
function readFileRow(libraryUrl, fileName, sheetName, rowNum, lastColumn, finalResults) {
var fileUrl = libraryUrl + "/" + fileName + "/Model/Ranges('" + sheetName + "!A" + rowNum + "|" + lastColumn + rowNum + "')?$format=atom";
return $.ajax({
url: fileUrl,
type: "GET",
error: function (request, status, error) {
console.log(error);
},
}).done(function(data) {
jsonData = xmlToJson(data.documentElement);
cells = serializeRange(jsonData);
if(cells) {
finalResults.push(cells);
rowNum++;
finalResults = readFileRow(libraryUrl, fileName, sheetName, rowNum, lastColumn, finalResults);
}
return $.when(finalResults);
});
}
Run Code Online (Sandbox Code Playgroud)
如您所见,我正在尝试通过在请求返回数据时递归调用该函数来解决异步问题,这意味着它必须继续运行。当我将console.log()放在返回值之前时,我可以看到它正在按需要编译结果。但是,调用readFileRow()的返回是在过程完成之前返回的,并且由第一个ajax查询的响应组成,显然没有通过.done()函数运行。我试过删除ajax调用前的return,但这只会导致异常,因为return不再可以使用,因此没有.done()函数。
任何人都可以发现此功能的问题吗?异步功能不是我的强项,我很沮丧。
看起来答案很简单,我没有完全理解与异步函数相关的各种方法正在做什么。我通过以下方式重组了该函数并使其按预期工作:
$("#updateClusterDetails").click(function() {
console.log("Update initiated");
var baseFile = "AIF%20Test.xlsx";
$.when(readFileRow(libraryUrl, baseFile, "Sheet1", 1, "E", new Array())).then(function(results) {
console.log(results);
});
});
/**
* Reads a file in SharePoint Library via ExcelRest and returns the document
*
* @params string libraryUrl
* @params string fileLocation
*
* @returns Document/HTML
**/
function readFile(libraryUrl, fileLocation) {
// The base url for the SharePoint document library
var fileUrl = libraryUrl + fileLocation;
return $.ajax({
url: fileUrl,
type: "GET",
error: function (request, status, error) {
console.log(error);
},
success: function(data) {
return $.when(data);
}
});
}
/**
* Reads a series of rows in an Excel file in SharePoint Library via ExcelRest and returns the row data
*
* @params string libraryUrl
* @params string fileName
* @params string sheetName
* @params int rowNum
* @params string lastColumn
* @params string[][] currentResults
*
* @returns string[][]
**/
function readFileRows(libraryUrl, fileName, sheetName, rowNum, lastColumn, currentResults) {
var fileUrl = "/" + fileName + "/Model/Ranges('" + sheetName + "!A" + rowNum + "|" + lastColumn + rowNum + "')?$format=atom";
return readFile(libraryUrl, fileUrl)
.then(function(data) {
jsonData = xmlToJson(data.documentElement);
cells = serializeRange(jsonData);
if(!cells) {
return $.when(currentResults);
}
else {
currentResults.push(cells);
return $.when(readFileRow(libraryUrl, fileName, sheetName, rowNum + 1, lastColumn, currentResults));
}
});
}
Run Code Online (Sandbox Code Playgroud)