Webview获取连续H5页面的标题

本文介绍如何在Android应用中使用Webview正确获取并设置H5页面的标题。通过WebChromeClient的onReceivedTitle方法可以监听标题变化,但当H5页面连续打开并回退时,标题可能无法更新。解决方案是利用集合记录每个URL对应的标题,并在onPageFinished中设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在应用中,有的页面会使用h5来实现,而title确是客户端来实现的,正确的获取h5的标题,设置正确的title

是必须的。

这个在webview中通过api很容易实现。只需要调用这个方法就可以了。

mWebView.setWebChromeClient(new WebChromeClient(){
            @Override
            public void onReceivedTitle(WebView view, String title) {
                super.onReceivedTitle(view, title);
                Log.v(TAG,"title:"+title);
            }
        });

这样的确可以实现设置标题,但是问题来了,你会发现当H5不断的打开,你的标题也跟着相应变化,但是当你点了back键后,页面不断的回退,但是标题确没有任何变化,打开log,原来返回的时候根本没有走onReceivedTitle这个方法。

这个时候,我们可以借助集合来解决这个问题,记录每个网址对应的title,然后在onpagefinish中进行设置。

//记录URL和title
    private String mCurrentUrl;
    private Map<String,String> titles = new HashMap<String,String>();
    mWebView.setWebViewClient(new WebViewClient(){
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                mWebView.loadUrl(url);
                return true;
            }

            @Override
            public void onPageStarted(WebView view, String url, Bitmap favicon) {
                super.onPageStarted(view, url, favicon);
                Log.v(TAG,"start:"+url);
                mCurrentUrl = url;
            }

            @Override
            public void onPageFinished(WebView view, String url) {
                super.onPageFinished(view, url);
                Log.v(TAG,"finish:"+url);
                String title = titles.get(url);
                if (!TextUtils.isEmpty(title)){
                    mTitle.setText(title);
                }
            }
        });

        mWebView.setWebChromeClient(new WebChromeClient(){
            @Override
            public void onReceivedTitle(WebView view, String title) {
                super.onReceivedTitle(view, title);
                Log.v(TAG,"title:"+title);
                if (TextUtils.isEmpty(title)){
                    title = "";
                }
                titles.put(mCurrentUrl,title);
            }
        });
好了,这样,在onpagestart中记录url,在onpagefinish中从集合中取出,这样就解决了问题。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值