Android WebView重写返回事件(history.go(-1))

由于项目是混编项目,当然ios和android两端都有,小程序也有,为了达到统一效果,当然也是省时省力了,需要用到识别认证,因为首页就是认证这个界面,在我认证结束后我需要finish掉这个界面,但是接入时是百度写好的history.go(-1),那我需要监听这个点击按钮,并且改掉他的事件才行

 

废话不多说,接下来我们需要写个工具类

import android.annotation.SuppressLint;
import android.text.TextUtils;
import android.webkit.WebView;
import android.webkit.WebViewClient;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;

public class WebViewGoBackSupport {
    /**
     * 自定义的,当js调用history.go时加载的链接,以监听history.go方法的调用
     */
    private final static String CONSTANTS_GO_BACK = "/CONSTANTS_GO_BACK#";
    /**
     * 当webview不能在返回时回调的方法
     */
    @Nullable
    private onBackClickLisnter whenCannotGoBackRunnable;
    @NonNull
    private WebView webview;

    /**
     * @param whenCannotGoBackRunnable 当没有上一个页面,而js调用了history.go时回调的方法
     */
    @SuppressLint("SetJavaScriptEnabled")
    public WebViewGoBackSupport(@NonNull WebView webview, @Nullable onBackClickLisnter whenCannotGoBackRunnable) {
        this.webview = webview;
        this.whenCannotGoBackRunnable = whenCannotGoBackRunnable;
        this.webview.getSettings().setJavaScriptEnabled(true);
    }

    /**
     * @param whenCannotGoBackRunnable 当没有上一个页面,而js调用了history.go时回调的方法
     * @param defaultClient            true时,不需要手动调用 onPageFinished、shouldOverrideUrlLoading
     */
    public WebViewGoBackSupport(@NonNull WebView webview, @Nullable onBackClickLisnter whenCannotGoBackRunnable, boolean defaultClient) {
        this(webview, whenCannotGoBackRunnable);
        if (defaultClient) {
            webview.setWebViewClient(new WebViewClient() {
                @Override
                public void onPageFinished(WebView view, String url) {
                    WebViewGoBackSupport.this.onPageFinished(url);
                    whenCannotGoBackRunnable.onLoadFinished();
                    super.onPageFinished(view, url);
                }

                @Override
                public boolean shouldOverrideUrlLoading(WebView view, String url) {
                    WebViewGoBackSupport.this.shouldOverrideUrlLoading(url);
                    return super.shouldOverrideUrlLoading(view, url);
                }
            });
        }
    }

    /**
     * 在WebViewClient对应方法中调用
     * 注:此方法需手动调用,或者使用defaultClient == true
     */
    public void onPageFinished(String url) {
        //重写js页面window.history.go方法
        String script = "javascript:(function(){window.history.go = function(index){" +
                "window.location.href='" + CONSTANTS_GO_BACK + "'+index;" +
                "}})()";
        webview.loadUrl(script);
    }

    /**
     * 在WebViewClient对应方法中调用
     * 注:此方法需手动调用,或者使用defaultClient == true
     */
    public void shouldOverrideUrlLoading(String url) {
        if (!TextUtils.isEmpty(url) && url.contains(CONSTANTS_GO_BACK)) {
            int step = -1;
            try {
                //解析js调用history.go时传入的参数
                step = Integer.parseInt(url.split("#")[1]);
            } catch (Exception e) {
                e.printStackTrace();
            }
            if (webview.canGoBackOrForward(step)) {
                webview.goBackOrForward(step);
            } else if (whenCannotGoBackRunnable != null) {
                //当没有上一个页面,而js调用了history.go时回调方法
                whenCannotGoBackRunnable.onBackListnerSuccess();
            }
        }
    }


    public interface onBackClickLisnter{
        void onBackListnerSuccess();
        void onLoadFinished();
    }

里面写了两个监听,我这边需求是需要加载完后隐藏掉加载框,所以这里我就写了一个加载finish的监听,再一个就是我们当这个界面上面没有上个界面了,但是却调用了history.go

 new WebViewGoBackSupport(webView, new WebViewGoBackSupport.onBackClickLisnter() {
             @Override
             public void onBackListnerSuccess() {
                 finish();
             }

             @Override
             public void onLoadFinished() {
                hideL();
             }
         }, true);

webview调用这个界面的时候,可以把本webview传进去,我们可以重写返回成功的事件,我这边是直接finish掉,当然,如果你需要跳转到别的界面也是可以的哈~,希望能对你有所帮助~

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值