我有一个 WebView,在使用 WebView.setWebViewClient 设置自定义 WebViewClient 后,似乎没有调用 WebViewClient 方法。特别是我覆盖了 onLoadResource 和 onReceivedError。但是,在调用 WebView.loadUrl(); 之后,这些都没有被调用;
这是有问题的代码:https ://gist.github.com/9673b619e019038848a0
我错过了什么?
我有一个 WebView,在使用 WebView.setWebViewClient 设置自定义 WebViewClient 后,似乎没有调用 WebViewClient 方法。特别是我覆盖了 onLoadResource 和 onReceivedError。但是,在调用 WebView.loadUrl(); 之后,这些都没有被调用;
这是有问题的代码:https ://gist.github.com/9673b619e019038848a0
我错过了什么?
您确定您正在寻找正确的日志消息并且您的设备正在正确输出日志吗?我基本上将您的代码复制到了一个干净的项目中,它似乎工作得很好。浏览一下文档,您似乎正在正确地遵循所有内容。
我使用 webview 作为内容视图,这是我看到的唯一显着差异。
以下是我的测试活动供参考:
package com.testing.androidtest;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.webkit.ConsoleMessage;
import android.webkit.WebChromeClient;
import android.webkit.WebView;
import android.webkit.WebViewClient;
@SuppressLint("SetJavaScriptEnabled")
public class MainActivity extends Activity {
private static final String APP_TAG = "MYAPP";
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
final WebView webView = new WebView(getApplicationContext());
webView.getSettings().setJavaScriptEnabled(true);
webView.setWebChromeClient(new WebChromeClient() {
@Override
public boolean onConsoleMessage(ConsoleMessage consoleMessage) {
Log.d(APP_TAG, consoleMessage.message());
return true;
}
});
webView.setWebViewClient(new WebViewClient() {
@Override
public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
Log.e(APP_TAG, "Error in WebView: " + failingUrl + "; " + description);
}
@Override
public void onLoadResource(WebView view, String url) {
super.onLoadResource(view, url);
Log.d(APP_TAG, "loading resource: " + url);
}
});
webView.loadUrl("http://google.com/");
setContentView(webView);
}
}