主线程上的 Firebase 同步 XMLHttpRequest 已弃用

Firebase Synchronous XMLHttpRequest on the main thread is deprecated

我正在开发 phonegap/cordova ionic 应用程序。我正在 iOS 和 Android 上进行测试。

在 iOS 上一切正常。

但是在 Android,当我的一个视图加载时我收到以下消息:

Synchronous XMLHttpRequest on the main thread is deprecated because of its detrimental effects to the end user's experience. For more help, check http://xhr.spec.whatwg.org/.

每次我收到这个 "warning" - 我的视图不会加载。

to/from firebase 的 .lp?dframe=t&id=...&pw=... 查询之一具有以下内容:

<html><body><script>
function EnvSendPing(destURL) {
try{
var xhr=new XMLHttpRequest();
xhr.open("GET", destURL, false);
xhr.send(null);
} catch (e) { }
}
function EnvDisconnect() {
EnvSendPing("/.lp?disconn=t&id=294802&pw=LL8E8eo2Rz");
}
if(window.addEventListener)
window.addEventListener('unload',EnvDisconnect,false);
else if(window.attachEvent)
window.attachEvent('onunload',EnvDisconnect);
</script></body></html>

这显然将 xhr 作为异步 "false" - 导致此 "warning"。

有没有一种方法可以强制所有 Firebase 查询的异步为真。 如果这只是一个 "warning" 为什么页面会停止?

请注意,在 iOS 和 Chrome 以及桌面上的 Safari 上 - 一切正常。

在我的例子中,问题是由于 ionic-service-deploy 文档所建议的 cordova.js 的注释造成的。

取消注释,确保 WS 与 Firebase 的顺利连接。为什么它应该是这样超出了我的范围 - 但我已经通过反复添加和删除我的 index.html 中的包含进行了测试,以便在 Android/4.4.4 设备上始终如一地再现效果。

希望这对其他人有帮助 - 我花了很多时间才找到它!