我们已经使用Excel JavaScript API开发了好几个月了。我们遇到了与情况相关的问题,这些问题由于不明原因而得到解决。我们无法复制这些问题,并想知道他们如何解决问题。最近类似的问题又开始出现了。 我们始终得到的错误:range.address引发上下文相关错误
property'address'is not available。在读取该属性的值 之前,请在包含对象上调用load方法,并在关联的请求上下文中调用 “context.sync()”。
我们认为,因为我们有多个定义为模块化代码的函数在项目中,可能会在不被注意到的这些函数之间的上下文有所不同。所以我们想出了通过JavaScript模块模式实现的单一上下文解决方案。
var ContextManager = (function() {
var xlContext;//single context for entire project/application.
function loadContext() {
xlContext = new Excel.RequestContext();
}
function sync(object) {
return (object === undefined) ? xlContext.sync() : xlContext.sync(object);
}
function getWorksheetByName(name) {
return xlContext.workbook.worksheets.getItem(name.toString());
}
//public
return {
loadContext: loadContext,
sync: sync,
getWorksheetByName: getWorksheetByName
};
})();
注意:上面的代码缩短了。还添加了其他方法以确保在整个应用程序中使用单个上下文。 虽然在实施单个上下文的同时,我们仍然能够复制该问题。
Office.initialize = function (reason) {
$(document).ready(function() {
ContextManager.loadContext();
function loadRangeAddress(rng, index) {
rng.load("address");
ContextManager.sync().then(function() {
console.log("Address: " + rng.address);
}).catch(function (e) {
console.log("Failed address for index: " + index);
});
}
for (var i = 1; i <= 1000; i++) {
var sheet = ContextManager.getWorksheetByName("Sheet1");
loadRangeAddress(sheet.getRange("A" + i), i);//I expect to see a1 to a1000 addresses in console. Order doesn't matter.
}
});
}
在上面的例子中,只有“A1”作为范围地址打印到控制台。我看不到任何其他地址(A2到A1000)正在打印。只有catch块执行。谁能解释为什么会发生这种情况? 虽然我上面写了for循环,但这不是我的用例。在实际使用情况下,这种情况发生在函数a中的一个范围对象需要加载范围地址的情况下。而另一个函数b也想加载范围地址。函数a和函数b在单独的任务上异步工作,例如创建表对象(表需要地址)和其他数据到工作表(其中有调试语句来查看数据被粘贴到哪里)。
这是我们的团队无法弄清楚或找到解决方案。