【问题标题】:Why is my WebView's WebViewClient not being called?为什么我的 WebView 的 WebViewClient 没有被调用?
【发布时间】:2012-07-11 18:15:53
【问题描述】:

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

这里是有问题的代码:https://gist.github.com/9673b619e019038848a0

我错过了什么?

【问题讨论】:

    标签: android webview webviewclient


    【解决方案1】:

    您确定您正在寻找正确的日志消息并且您的设备正在正确输出日志吗?我基本上将您的代码复制到了一个干净的项目中,它似乎工作得很好。浏览一下文档,您似乎正确地遵循了所有内容。

    我使用 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);
        }
    
    }
    

    【讨论】:

      猜你喜欢
      • 2018-07-11
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2023-03-22
      • 1970-01-01
      • 2022-10-15
      • 2011-04-11
      • 2023-03-07
      相关资源
      最近更新 更多