同一线程错误的 WebView 方法
Posted
技术标签:
【中文标题】同一线程错误的 WebView 方法【英文标题】:WebView methods on same thread error 【发布时间】:2014-05-01 16:57:39 【问题描述】:我有一个 android 程序(Web 视图中的 Java + html)。我可以从 javascript 调用 Java 代码。但反过来停止工作(在 Eclipse 中更新后)。
这就是我想要做的事情
制作网页视图(成功) 在 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 Looper41ab68f8 called on Looper41bb70a8, FYI main Looper is Looper41ab68f8)
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..");
【问题讨论】:
在您的编辑中,您提到您已经根据(一个)答案更改了代码,听起来这仍然没有解决您的问题 - 但有一个接受回答。我建议您明确说明这是否解决了问题(或者只是撤消编辑)。 【参考方案1】:JavaScript 方法在后台(即非 UI)线程上执行。您需要在 UI 线程上调用所有与 Android View 相关的方法。您可以通过以下方式实现您的需求:
mWebView.post(new Runnable()
@Override
public void run()
mWebView.loadUrl(...).
);
这将发布任务以在 UI 线程上运行。
【讨论】:
您在哪里将 sn-p (mWebView) 添加到您的原始代码中? 在 test() 函数中,见我上面的问题。 如果需要返回值怎么办?例如返回 webview.getUrl? ***.com/questions/29748782/…@JohanHoeksma 您知道这个问题是如何以及何时发生的吗?在我的 Nexus 5X(Android 7.1.1) 上,没问题,但有些设备崩溃了。 如何传递变量?我试图在 mWebView.loadUrl("javascript:test('" + MyData + "');"); 中添加变量但是该值永远不会传递给javascript!【参考方案2】:在我的情况下,WebView 中没有显示任何内容,所以我更喜欢另一种方式:
runOnUiThread(new Runnable()
@Override
public void run()
final WebView webView = (WebView) findViewById(R.id.map);
webView.loadDataWithBaseURL(...);
);
【讨论】:
【参考方案3】:Java版本:必须使用Runnable接口和Post to Handler。
webView.post(new Runnable()
@Override
public void run()
webView.loadUrl("file:///android_asset/www/index.html");
);
Kotlin 版本:
webView.post(new Runnable
webView.loadUrl("file:///android_asset/www/index.html")
)
【讨论】:
【参考方案4】:这可以通过使用 post 方法来解决。请通过以下代码。
m_targetView.post(new Runnable()
@Override
public void run()
m_targetView.loadUrl(".....");
);
【讨论】:
以上是关于同一线程错误的 WebView 方法的主要内容,如果未能解决你的问题,请参考以下文章
是否可以分离 WebView 的 UI 和 HTTP 线程?
Flutter - html页面内带有href链接的WebView错误