WebView进阶 设置JS交互和加载进度监听

本文将深入探讨如何在WebView中实现JavaScript交互功能,并详细讲解如何设置加载进度监听,确保网页内容在WebView内平滑显示,避免跳转到系统浏览器。

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

先设置webview的js交互和设置不跳转系统浏览器

//获取控件
mClassicweb=(WebView)findViewById(R.id.classic_web);
//设置支持JS
mClassicweb.getSettings().setJavaScriptEnabled(true);
mClassicweb.getSettings().setAppCacheEnabled(true);
//设置 缓存模式
mClassicweb.getSettings().setCacheMode(WebSettings.LOAD_DEFAULT);
// 开启 DOM storage API 功能
mClassicweb.getSettings().setDomStorageEnabled(true);
//设置url
mClassicweb.loadUrl(mWeburl);
//设置不跳浏览器
mClassicweb.setWebViewClient(new WebViewClient() {
    //重写shouldOverrideUrlLoading 方法
    @Override
    public boolean shouldOverrideUrlLoading(WebView view, String url) {
    	//传上面设置的url
        view.loadUrl(url);
        //返回真
        return true;
    }
});

设置跳到WebView的时候显示的加载进度

//创建一个ProgressDialog 提上去
dialog = ProgressDialog.show(this, "正在加载…", null);
//设置进度监听
mClassicweb.setWebViewClient(new WebViewClient(){
    @Override
    public void onPageFinished(WebView view, String url) {
        super.onPageFinished(view, url);
        toase("加载完毕~",1);
        //设置消失
        dialog.dismiss();
    }
    
    @Override
    public void onPageStarted(WebView view, String url, Bitmap favicon) {
        super.onPageStarted(view, url, favicon);
//                toase("正在加载中~",1);
    }
});
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值