在恶劣的网络条件下测试我们的Office.js加载项时,遇到了一个问题。以下错误被抛出我们的脚本加载即使之前:
Uncaught Office.js has not been fully loaded yet. Please try again later or make sure to add your initialization code on the Office.initialize function.
有没有办法在Office.js中禁用初始化定时器?
调试了几个小时后,我们发现下面的一段代码Office.js
:
g.waitForFunction(function() {
return Microsoft.Office.WebExtension.initialize != undefined
}, function(a) {
if (a) {
if (h.prepareApiSurface)
Microsoft.Office.WebExtension.initialize(h.getInitializationReason(b));
else
h.prepareRightBeforeWebExtensionInitialize(b);
h.prepareRightAfterWebExtensionInitialize && h.prepareRightAfterWebExtensionInitialize()
} else
throw "Office.js has not been fully loaded yet. Please try again later or make sure to add your initialization code on the Office.initialize function."
}, 400, 50)
的waitForFunction
方法需要4个参数:
function
- 状态检查函数返回一个布尔值。
function
- 当状态检查函数返回true
或方法失败时调用的回调函数。
Number
- 重试次数。
Number
- 尝试之间的毫秒数。
根据我们找到的源代码,Office加载项在框架超时并且简单放弃之前需要约20秒才能初始化。这在Office 365联机和连接速度慢的情况下特别有问题。
以下附加重现该问题:
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=Edge" />
<title>Test Init</title>
<script src="//appsforoffice.microsoft.com/lib/1/hosted/office.js"></script>
</head>
<body class="ms-font-l" style="width:100%;height:100%;overflow:hidden;position:relative;">
<div id="app" style="height:100%"></div>
<script>
console.log('Our script loaded...');
setTimeout(function() {
Office.initialize = function() {
console.log('Our App Initialized!!!')
};
}, 15000);
</script>
</body>
</html>
我的问题是,有没有办法绕过这个超时?或者至少增加它?也许使用类似:
Office.initialize(function() { /* ... */ });
而不是:
Office.initialize = function() { /* ... */};
如果没有,会Office团队考虑改变定时器,而不是使用一个属性:
Object.defineProperty(Office, 'initialize', {
get: function() { return Office._initialize; },
set: function(value) { Office._initialize = value; Office.triggerCodeDependantOnInitialize(); }
});