我们最近更改了Worklight连接设置,以便应用无法连接到Worklight Server。
在此更改之后,显示Native页面(AppInit.js)的代码不再返回到JavaScript回调函数。
似乎Native页面运行到最后,但我对WL.Logger.log('backFromNativeLoginPage');
的调用没有被执行。它挂在最后一个可见页面上,直到手机进入睡眠模式然后由用户恢复,或者如果用户切换到主屏幕并切换回应用程序。之后,执行回调代码。
我还注意到LogCat中的一个条目,我之前没有注意到:
THREAD WARNING:exec()调用Logger.LOG阻塞了主线程 44ms。插件应该使用CordovaInterface.getThreadPool()
我将connectOnStartup
设置为true
的唯一方法是让我正常工作。我不确定为什么它依赖于服务器上的服务器连接从本机页面返回?由于连接到服务器不是我们的选择,有人知道是否有解决方法?有没有人见过这个?
这是我的代码:
AppInit.js
var showNativePage = function() {
WL.NativePage.show('com.app.Login', function(data) {
WL.Logger.log('backFromNativeLoginPage'); //Does not run if connectOnStartup=false
}, {param: 'some value'});
};
initOptions.js
var wlInitOptions = {
connectOnStartup: false //setting this to true works
};
WLJSX.bind(window, 'load', function() {
WL.Client.init(wlInitOptions);
});
Login.java
public class Login extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
LoginWebViewClient client = new LoginWebViewClient(this);
webView = (WebView) findViewById(R.id.login);
webView.getSettings().setJavaScriptEnabled(true);
webView.setWebViewClient(client);
webView.loadUrl(url);
}
public void setAppDataAndReturn(HashMap<String, String> dataList) {
Intent returnData = new Intent();
for (Map.Entry<String, String> item : dataList.entrySet()) {
returnData.putExtra(item.getKey(), item.getValue());
}
setResult(RESULT_OK, returnData);
finish();
}
}
更新
在尝试了一些建议之后,我在Cordova events上看到了一些文档,然后跟着它,我终于通过在AppInit.js文件中添加以下代码来实现它:
function wlEnvInit() {
wlCommonInit();
document.addEventListener("deviceready", function(info) {
document.addEventListener("resume", function(e){ WL.Logger.log('Resume from native page.'); }, false);
});
}
我不确定为什么会这样,但似乎需要WL.Logger.log()
语句,因为如果没有它,回调就不会执行。如果有人能够解释为什么它以这种方式运作,我有兴趣知道。希望这个&#39;解决方法&#39;帮助可能遇到同样问题的人...
答案 0 :(得分:2)
我看到你在initOptions.js中有以下代码:
WLJSX.bind(window, 'load', function() {
WL.Client.init(wlInitOptions);
});
这会导致在浏览器(或混合应用中的webview)WL.Client.init
事件中调用load
函数。由WL.Client.init
触发的代码路径下的某些可执行代码依赖于Cordova完全初始化。 connectOnStartup: true
指令触发依赖于已完全初始化的Cordova的代码路径。完整的Cordova初始化由deviceready
事件指示。
您在WL.Client.init
事件之前触发deviceready
。因此,您会看到意外行为。
我强烈建议删除load
事件绑定和回调代码,并将所有初始化代码放在wlCommonInit
或wlEnvInit
中,这些代码在deviceready
事件中触发。您不需要在代码中明确监听deviceready
。