javascript - 同一线程错误的 WebView 方法

标签 javascript android android-webview

我有一个 android 程序(Web View 中的 Java + html)。我可以从 javascript 调用 Java 代码。但反过来停止工作(在 Eclipse 中更新后)。

这就是我想要做的事情

  • 制作一个网页 View (成功)
  • 在 javascript 中调用 AndroidFunction.test(); (工作)
  • java test() 函数调用 webView.loadUrl("javascript:helloBack()"); (!不再工作了)

我试图让它与 MainActivity 中的 WebView 一起工作,但没有成功。

MainActivity.java

public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        final WebView webView = (WebView)findViewById(R.id.webView);
        webView.getSettings().setJavaScriptEnabled(true);
        webView.setWebChromeClient(new WebChromeClient());
        WebSettings webSettings = webView.getSettings();
        webSettings.setJavaScriptEnabled(true);

        javascr = new Javascript(this, webView);
        webView.addJavascriptInterface(javascr, "AndroidFunction");
        webView.loadUrl("file:///android_asset/www/index.html");

        ....
}

Javascript.java

public class Javascript {   
    Context cont;
    WebView webView;

    Javascript(Context c, WebView w) {
        cont = c;
        webView = w;
    }

    // function called in the javascript by AndroidFunction.test();
    public void test() {
          // Breaking point!!!
        webView.loadUrl("javascript:helloBack()");
    }

错误:

03-24 11:47:50.103: W/WebView(21026):   at com.android.org.chromium.base.SystemMessageHandler.handleMessage(SystemMessageHandler.java:27)
03-24 11:47:50.103: W/WebView(21026):   java.lang.Throwable: A WebView method was called on thread 'JavaBridge'. All WebView methods must be called on the same thread. (Expected Looper Looper{41ab68f8} called on Looper{41bb70a8}, FYI main Looper is Looper{41ab68f8})

03-24 11:47:50.103: W/WebView(21026):   at android.webkit.WebView.checkThread(WebView.java:2063)
03-24 11:47:50.103: W/WebView(21026):   at android.webkit.WebView.loadUrl(WebView.java:794)
03-24 11:47:50.103: W/WebView(21026):   at com.example.hellobt.Javascript.test(Javascript.java:24)

03-24 11:47:50.103: W/WebView(21026):   at com.android.org.chromium.base.SystemMessageHandler.nativeDoRunLoopOnce(Native Method)
03-24 11:47:50.103: W/WebView(21026):   at com.android.org.chromium.base.SystemMessageHandler.handleMessage(SystemMessageHandler.java:27)
03-24 11:47:50.103: W/WebView(21026):   at android.os.Handler.dispatchMessage(Handler.java:102)

03-24 11:47:50.103: W/WebView(21026):   at android.os.Looper.loop(Looper.java:137)
03-24 11:47:50.103: W/WebView(21026):   at android.os.HandlerThread.run(HandlerThread.java:61)

感谢您的回答。我在我的 Javascript 文件中编辑了这样的函数:

private void test(final String s) {
        webView.post(new Runnable() {
            public void run() {
                webView.loadUrl("javascript:" + s + ";");
            }
        });
        System.out.println("javscript done..");
    }

最佳答案

JavaScript 方法在后台(即非 UI)线程上执行。您需要在 UI 线程上调用所有与 Android View 相关的方法。您可以通过以下方式实现您的需求:

mWebView.post(new Runnable() {
    @Override
    public void run() {
        mWebView.loadUrl(...).
    }
});

这将发布任务以在 UI 线程上运行。

关于javascript - 同一线程错误的 WebView 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22607657/

相关文章:

javascript - element.classList.toggle 中的第二个参数有什么意义?

javascript - jQuery : How to operate a plugin on two input boxes

android - CardView 都相互堆叠

android - WebView 不调整大小

Android TextView 可点击 <a href/> 标签并链接到浏览器

Javascript - 在更改函数之前保留对函数的引用

javascript - 获取 JavaScript 对象文字中键的兄弟值

android - 在 Android 中读取 Assets 或原始文件夹中的文件

android - Facebook android 集成中的注销功能禁用

android - 在 Android 中显示 SCORM 内容