Android WebView-使用Javascript设置HTML字段焦点

|| 我有一个带有可见的“ 0”组件的应用程序,该组件用于显示一些动态生成的HTML(也可以运行Javascript)。启用了“ 0”。 对于几页,我试图在页面加载完成后设置输入文本框之一的焦点-不是通过Body
onLoad()
,而是在页面加载完成后(即在
onPageFinished()
中)通过JS调用。大部分javascript执行正常
    webview.loadURL(\"javascript:JSMethod();\");
但是,当我使用相同的调用执行
document.getElementById(\'text1\').focus()
时,光标确实到达了元素,但pop6ѭ不会弹出。从页面上的按钮执行时,相同的javascript代码确实具有所需的效果。 我正在附上具有3个按钮的源代码
Focus Text1
-将光标放在文本1上,然后弹出软键盘。
Java Focus Text1
-调用Java执行相同的JS。仅在此处显示光标,而不会弹出键盘
Java Focus Text1 And Keyboard Open
-从Java调用JS,并强制打开键盘。 我的理解是,无论是使用按钮/事件从浏览器执行还是通过Java通过
WebView.loadURL()
发送,JS执行都应相同。 这是我的查询 使用
Button#2
时会丢失东西吗?这就是我当前的代码,只看到光标已设置,但软键盘无法打开。 当我使用ѭ12中编写的逻辑时,有时我在字段上看不到光标,但是给了我想要的效果,并且当我在弹出的键盘中键入内容时,光标变得可见。 我在ѭ11中看到的行为是否可能是Android JS执行中的错误?还是be0ѭ没有焦点,这就是为什么只显示光标的原因?我还尝试了
webview.requestFocus()
-我不能写
requestFocusOnTouch()
,因为它是我唯一的视图,并且希望它能自动聚焦。 演示行为的Java代码是
    import android.app.Activity;
    import android.content.Context;
    import android.os.Bundle;
    import android.util.Log;
    import android.view.inputmethod.InputMethodManager;
    import android.webkit.JsResult;
    import android.webkit.WebChromeClient;
    import android.webkit.WebView;
    import android.webkit.WebViewClient;

    public class WebViewProjectTestJSHTMLFocusActivity extends Activity {

        Activity _current = null;
        WebView wv = null;

        /** Called when the activity is first created. */
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            _current = this;
            //setContentView(R.layout.main);
            String data = \"<html><body>\" +
                                \"<script>function focusser() { document.getElementById(\\\"text1\\\").focus(); } </script>\" +
                                \"<script>function javaFocusser() { javautil.javaFocus(false); } </script>\" +
                                \"<script>function javaFocusserKeyboard() { javautil.javaFocus(true); } </script>\" +
                                \"Text 1<input type=\'text\' id=\'text1\'/><br/>\" +
                                \"Text 2<input type=\'text\' id=\'text2\'/><br/>\" +
                                \"<input type=\'button\' value=\'Focus Text1\' onClick=\'focusser()\'/>\" +
                                \"<input type=\'button\' value=\'Java Focus Text1\' onClick=\'javaFocusser()\'/>\" +
                                \"<input type=\'button\' value=\'Java Focus Text1 And Keyboard Open\' onClick=\'javaFocusserKeyboard()\'/>\" +
                            \"</body></html>\";
            wv = new WebView(this);
            wv.getSettings().setJavaScriptEnabled(true);

            // Set some HTML 
            wv.loadDataWithBaseURL(\"file:///android_asset/\", data, \"text/html\", \"UTF-8\", null);

            // Call back required after page load finished
            wv.setWebViewClient(new CustomWebViewClient());

            // Enable Alert calls  
            wv.setWebChromeClient(new CustomWebChromeClient());

            // For JS->Java calls
            wv.addJavascriptInterface(this, \"javautil\");

            setContentView(wv);
        }


        /**
         * Calls the same javascript and forces the keyboard to open 
         */
        public void javaFocus(final boolean shouldForceOpenKeyboard) {

            Thread t = new Thread(\"Java focusser thread\") {
                public void run() {
                    wv.loadUrl(\"javascript:focusser();\");
                    if(shouldForceOpenKeyboard) {
                        InputMethodManager mgr = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
                        mgr.showSoftInput(wv, InputMethodManager.SHOW_IMPLICIT);
                    }
                }
            };

            // Run on the View Thread.
            _current.runOnUiThread(t);
        }

        /**
         * Calls focus method after the page load is complete.
         */
        final class CustomWebViewClient
        extends WebViewClient {
            @Override
            public void onPageFinished(WebView view, String url) {
                // javaFocus(true);
                Log.d(\"TestExamples\", \"focusser call complete\");
            }
        }

        final class CustomWebChromeClient
        extends WebChromeClient {
            @Override
            public boolean onJsAlert(WebView view, String url, String message, JsResult result) {
                Log.d(\"TestExamples\", \"JS Alert :: \" + message);
                return false;
            }
        }
    }
解决方案更新24-06-2011 要使此工作有效,您需要在实际的JS焦点调用之前使用ѭ18。我将上面的
javaFocus()
方法修改为下面的正确版本。前面提到当我使用requestFocus()时,是在方法ѭ21when中初始化
WebView
时使用的。现在的主要区别是,在每次执行Javascript
document.getElementById(\"text1\").focus();
之前,我们都强制ѭ0focus获得焦点。
public void javaFocus(final boolean shouldForceOpenKeyboard) {
    Thread t = new Thread(\"Java focusser thread\") {
        public void run() {
            wv.requestFocus(View.FOCUS_DOWN);
            wv.loadUrl(\"javascript:focusser();\");
            if(shouldForceOpenKeyboard) {
                InputMethodManager mgr = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
                mgr.showSoftInput(wv, InputMethodManager.SHOW_IMPLICIT);
            }
        }
    };

    // Run on the View Thread.
    _current.runOnUiThread(t);
}
另外,为了确保由于触摸等触发焦点导致此问题未得到解决,我正在使用后台线程在显示WebView 5秒后初始化javaFocus()。修改后的
onCreate()
如下。
..... More onCreate code before....
// Enable Alert calls  
wv.setWebChromeClient(new CustomWebChromeClient());

// For JS->Java calls
wv.addJavascriptInterface(this, \"javautil\");

setContentView(wv);

new Thread(\"After sometime Focus\") {
    public void run() {
        try {
            Thread.sleep(5000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        javaFocus(true);
    }
}.start();
.... onCreate() ends after this.... 
    
已邀请:
可能是Web视图没有针对应用程序的关注。尝试执行;
wv.requestFocus(View.FOCUS_DOWN);
    

要回复问题请先登录注册