为什么我的WebView的WebViewClient没有被调用?

时间:2012-07-11 18:15:53

标签: android webview webviewclient

我有一个WebView,在使用WebView.setWebViewClient设置自定义WebViewClient之后,似乎没有调用WebViewClient方法。特别是我重写onLoadResource和onReceivedError。但是,在调用WebView.loadUrl();

之后,这些都不会被调用

以下是相关代码:https://gist.github.com/9673b619e019038848a0

我错过了什么?

1 个答案:

答案 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);
    }

}