美文网首页
webView的基本配置、Post传参、弹出框和二次跳转的处理

webView的基本配置、Post传参、弹出框和二次跳转的处理

作者: white_or_black | 来源:发表于2017-09-20 09:38 被阅读0次

基本配置


        //设置WebView属性,能够执行Javascript脚本
        WebSettings settings = webView.getSettings();//获得WebView的设置

        //支持js,必须设置
        settings.setJavaScriptEnabled(true);
        //大部分网页需要自己保存一些数据
        settings.setDomStorageEnabled(true);
        //设置数据的缓存路径
        String appCachePath = getApplicationContext().getCacheDir().getAbsolutePath();
        settings.setAppCachePath(appCachePath);
        settings.setAllowFileAccess(true);
        settings.setAppCacheEnabled(true);

        //设置webView推荐的窗口
        settings.setUseWideViewPort(true);
        //适配
        settings.setLoadWithOverviewMode(true);

Post方式传值(auth值是约定key值。不同的项目请不同对待)

  String params = "auth=" + MyApplication.getInstance().getAuth();
  webView.postUrl(url, params.getBytes());

js弹出框

  /**
     * js弹出框的处理
     */
    private class MyWebChromeClient extends WebChromeClient {
        @Override
        public boolean onJsAlert(WebView view, String url, String message,
                                 final JsResult result) {
            // 弹窗处理(title和positive按钮的文字可以自己设置)
            AlertDialog.Builder b2 = new AlertDialog.Builder(CommonWebViewActivity.this)
                    .setTitle(R.string.app_name).setMessage(message)
                    .setPositiveButton("ok", new AlertDialog.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            result.confirm();
                        }
                    });
            b2.setCancelable(false);
            b2.create();
            b2.show();
            return true;
        }
    }

 webView.setWebChromeClient(new MyWebChromeClient());

二次跳转和拨打电话的原理是一样的。都是捕捉js中的url(注意电话权限)

注意在不同的版本的处理。(获取url的方式不同)

 /**
     * 对js里面的点击事件进行处理(比如跳转和拨打电话)
     */
    private class MyWebViewClient extends WebViewClient {
        public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
            String tag = "tel:";             //电话的标签(具体tag值和其他人员协商)
            String href_url;
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
                href_url = request.getUrl().toString();
                if (href_url != null && href_url.contains(tag)) {
                    String mobile = href_url.substring(request.getUrl().toString().lastIndexOf(":") + 1);
                    Intent intent = new Intent(Intent.ACTION_DIAL, Uri.parse("tel:" + mobile));
                    startActivity(intent);
                } else {
                    webView.loadUrl(href_url);
                }
            } else {
                href_url = request.toString();
                if (href_url != null && href_url.contains(tag)) {
                    String mobile = href_url.substring(href_url.lastIndexOf(":") + 1);
                    Intent intent = new Intent(Intent.ACTION_DIAL, Uri.parse("tel:" + mobile));
                    startActivity(intent);
                } else {
                    view.loadUrl(request.toString());
                }
            }
            //返回false,意味着请求过程里,不管有多少次的跳转请求(即新的请求地址),均交给webView自己处理,这也是此方法的默认处理
            //返回true,说明你自己想根据url,做新的跳转,比如在判断url符合条件的情况下,我想让webView加载http://ask.csdn.net/questions/178242
            return true;
        }
        @Override
        public void onPageFinished(WebView view, String url) {
            super.onPageFinished(view, url);
            //设置标题
            tv_title.setText(view.getTitle());
        }
    }
 webView.setWebViewClient(new MyWebViewClient());

完整的代码

public class CommonWebViewActivity extends Activity {

    @Bind(R.id.webView)
    WebView webView;

  String url = "www.baidu.com";(比如百度)

   @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_common_web_view);
        ButterKnife.bind(this);

        initView();
    }

private void initView() {

        //设置WebView属性,能够执行Javascript脚本
        WebSettings settings = webView.getSettings();//获得WebView的设置

        //支持js,必须设置
        settings.setJavaScriptEnabled(true);
        //大部分网页需要自己保存一些数据
        settings.setDomStorageEnabled(true);
        //设置数据的缓存路径
        String appCachePath = getApplicationContext().getCacheDir().getAbsolutePath();
        settings.setAppCachePath(appCachePath);
        settings.setAllowFileAccess(true);
        settings.setAppCacheEnabled(true);

        //设置webView推荐的窗口
        settings.setUseWideViewPort(true);
        //适配
        settings.setLoadWithOverviewMode(true);

        //对一些常用操作的处理。如弹出框
        webView.setWebChromeClient(new MyWebChromeClient());
        webView.setWebViewClient(new MyWebViewClient());

        //Post传值
        String params = "auth=" + MyApplication.getInstance().getAuth();
        webView.postUrl(url, params.getBytes());
    }

 /**
     * js弹出框的处理
     */
    private class MyWebChromeClient extends WebChromeClient {
        @Override
        public boolean onJsAlert(WebView view, String url, String message,
                                 final JsResult result) {
            // 弹窗处理
            AlertDialog.Builder b2 = new AlertDialog.Builder(CommonWebViewActivity.this)
                    .setTitle(R.string.app_name).setMessage(message)
                    .setPositiveButton("ok", new AlertDialog.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            result.confirm();
                        }
                    });
            b2.setCancelable(false);
            b2.create();
            b2.show();
            return true;
        }


    }

    /**
     * 对js里面的点击事件进行处理(比如跳转和拨打电话)
     */
    private class MyWebViewClient extends WebViewClient {


        public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
            String tag = "tel:";             //电话的标签
            String href_url;
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
                href_url = request.getUrl().toString();
                if (href_url != null && href_url.contains(tag)) {
                    String mobile = href_url.substring(request.getUrl().toString().lastIndexOf(":") + 1);
                    Intent intent = new Intent(Intent.ACTION_DIAL, Uri.parse("tel:" + mobile));
                    startActivity(intent);
                } else {
                    webView.loadUrl(href_url);
                }
            } else {
                href_url = request.toString();
                if (href_url != null && href_url.contains(tag)) {
                    String mobile = href_url.substring(href_url.lastIndexOf(":") + 1);
                    Intent intent = new Intent(Intent.ACTION_DIAL, Uri.parse("tel:" + mobile));
                    startActivity(intent);
                } else {
                    view.loadUrl(request.toString());
                }
            }
            //返回false,意味着请求过程里,不管有多少次的跳转请求(即新的请求地址),均交给webView自己处理,这也是此方法的默认处理
            //返回true,说明你自己想根据url,做新的跳转,比如在判断url符合条件的情况下,我想让webView加载http://ask.csdn.net/questions/178242
            return true;
        }

        @Override
        public void onPageFinished(WebView view, String url) {
            super.onPageFinished(view, url);
            //设置标题
            tv_title.setText(view.getTitle());
        }
    }

}

有不对或者不完善的地方,还请多多指教。欢迎大家积极留言。

相关文章

网友评论

      本文标题:webView的基本配置、Post传参、弹出框和二次跳转的处理

      本文链接:https://www.haomeiwen.com/subject/fcunsxtx.html