使用 InAppBrowser 和微调器加载页面后无法输入输入字段

Can't type in input field after loading a page with InAppBrowser and spinner loading

我遇到了一个非常有趣的问题。我在我的 Android 应用程序之一中使用了 inAppBrowser 和微调器。 Spinner 是用 ProgressDialog 实现的。这里的问题是,当我尝试通过 inAppBrowser 打开网页时,加载微调器在页面开始加载后开始加载,然后在页面加载完成后关闭,当我点击该页面的输入字段并尝试输入字母或数字,它只会停留在所谓的 "locked" 状态。如果我输入一些我看不到的东西,光标就会一直闪烁。

为了让这更奇怪,我可以输入特殊字符。如果我点击页面周围的任何其他地方,然后再次点击相同的输入字段,那么它就可以工作了。另一种情况是当我将应用程序置于暂停状态然后恢复时,输入字段有效。

此问题仅出现在 Android 版本 5.0.1 及更早版本的平台中。

inAppBrowser java 文件可以在 Github 的 InAppBrowser java file 中找到。

我的微调器实现如下:

spinner = new ProgressDialog(cordova.getActivity());
spinner.setIndeterminate(false);
spinner.setProgressStyle(ProgressDialog.STYLE_SPINNER);
spinner.setCancelable(false);
spinner.setMessage(cordova.getActivity().getText(R.string.spinner_loading));
spinner.setTitle("");

我 show/hide 一个微调器,方法如下:

@Override
public void onPageStarted(WebView view, String url,  Bitmap favicon) {
    super.onPageStarted(view, url, favicon);
    //InAppBrowser default code....

    try {
        JSONObject obj = new JSONObject();
        obj.put("type", LOAD_START_EVENT);
        obj.put("url", newloc);

        sendUpdate(obj, true);

    } catch (JSONException ex) {
        Log.d(LOG_TAG, "Should never happen");
    }

    spinner.show();
}

public void onPageFinished(WebView view, String url) {
    super.onPageFinished(view, url);
    try {
        JSONObject obj = new JSONObject();
        obj.put("type", LOAD_STOP_EVENT);
        obj.put("url", url);

        sendUpdate(obj, true);

    } catch (JSONException ex) {
         Log.d(LOG_TAG, "Should never happen");
    }

    spinner.hide();
}

这可能是什么问题?任何提示,建议将不胜感激。

现在我可以解决问题了。问题是该特定页面输入字段的焦点。出于某种原因,一旦页面加载完成,它就没有将焦点放在自己身上。

尝试使用 editText.clearFocus() 解决 inAppBrowser 的 inAppBrowser.java 文件中的问题,然后 editText.requestFocus() 根本没有帮助。但对我有用的是以下解决方案。

由于 inAppBrowser 有一个名为 executeScript() 的方法,我能够将一些 Javascript 代码注入到出现此问题的特定输入字段。因此下面的代码起到了作用:

var ref = cordova.InAppBrowser.open('http://apache.org', '_blank',  location=yes');
ref.addEventListener('loadstop', function() {
    ref.executeScript({code: "$('#element').blur(); $('#element').focus();"});
});

该代码的作用是首先清除该特定元素的焦点,然后再次关注同一元素。

无论版本如何,这都适用于任何平台。

如果有人和我一样遇到这个问题,请尝试将 InAppBrowser 插件更新到最新版本 (1.7.2)。

ionic cordova plugin rm cordova-plugin-inappbrowser --save
ionic cordova plugin add cordova-plugin-inappbrowser --save

版本1.7.2有这个fix

我正在使用 Ionic (v3)。