我有一个WebView,在使用WebView.setWebViewClient设置自定义WebViewClient之后,似乎没有调用WebViewClient方法。特别是我重写onLoadResource和onReceivedError。但是,在调用WebView.loadUrl();
之后,这些都不会被调用以下是相关代码:https://gist.github.com/9673b619e019038848a0
我错过了什么?
答案 0 :(得分:0)
您确定要查找正确的日志消息,并且您的设备正在正确输出日志记录吗?我基本上将你的代码复制到一个干净的项目中,看起来效果很好。看一下文档,看起来你正在正确地关注所有内容。
我使用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);
}
}