IBM Worklight 6.1 - 如果处于脱机模式,则不会调用NativePage.show回调

时间:2014-03-03 20:46:34

标签: javascript android cordova ibm-mobilefirst

我们最近更改了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;帮助可能遇到同样问题的人...

1 个答案:

答案 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事件绑定和回调代码,并将所有初始化代码放在wlCommonInitwlEnvInit中,这些代码在deviceready事件中触发。您需要在代码中明确监听deviceready