webview初识

定义   

           一个view控件用于加载web页面(目前比较流行的H5页面)

需要的权限

          webview显然是网络请求的控件,所以使用时必须加入网络请求

用法

        a ) 用手机自带的浏览器中打开目标链接

              Uri uri = Uri.parse("http://www.example.com");

              Intent intent = new Intent(Intent.ACTION_VIEW, uri);

              startActivity(intent);

        b ) 在activity组件中显示webview

              WebView webview = new WebView(this);

              //或者有webview = findviewbyid(R.id.....)

              setContentView(webview);

              有目标网络地址:webview.loadUrl(要加载的网络地址);

              // OR, you can also load from an HTML string:

              直接拼接字符串形成前端页面

              String summary = "You scored 192";

              webview.loadData(summary, "text/html", null);

         c )在webview中添加自己的行为用法:

                  c.1 执行浏览器的UI变化,比如进度条和alert的通知窗口,

                         可以给webview如下设置

           webchromeClient,这时会调用webchromeClient的方法

           getWindow().requestFeature(Window.FEATURE_PROGRESS);//设置窗口风格为进度条

           webview.getSettings().setJavaScriptEnabled(true);//设置页面javascript可用

           final Activity activity = this;

          //在webchromeClient里设置进度条更新

          webview.setWebChromeClient(new WebChromeClient() {

          public void onProgressChanged(WebView view, int progress) {

                   // Activities and WebViews measure progress with different scales.

                  // The progress meter will automatically disappear when we reach 100%

                   activity.setProgress(progress * 1000);

           }

});

            c.2  当网页内容出现加载错误,错误提交或者是响应超链接时,

                   可以给webview设置一个webviewclient,

                   超链接会调用webclient里重写的shouldWverrideUrlLoading方法。

                   下面是一个示例,在一个H5页面上点击一个超链接,获取json数据:

         //在webviewClient里处理请求错误

         webview.setWebViewClient(new WebViewClient() {

                    public void onReceivedError(WebView view, int errorCode,

                           String   description, String failingUrl) {

                                Toast.makeText(activity, "Oh no! " +                                                            description,Toast.LENGTH_SHORT).show();

                     }

});

          webview.loadUrl("http://developer.android.com/");

          //在webview里响应超链接

          webView.getSettings().setJavaScriptEnabled(true);

          webView.loadUrl("***********");

           webView.setWebViewClient(new WebViewClient() {

                        @Override

                       public boolean shouldOverrideUrlLoading(WebView view,String url) {

                                 //这里传入的url是响应的超链接url,和webview加载的url不同

                                 if (url != null) {

                                        if ("min://api/getInfo".equals(url)) {

                                                JSONObject jsonObject = new JSONObject();

                                                try {                                      

                                                           jsonObject.put("version"

                                                               ,android.os.Build.VERSION.SDK_INT);

                                                         jsonObject.put("man", "min");

                                                 } catch (JSONException e) {

                                                        e.printStackTrace();

                                                 }

                                           //String call = "javascript:alertMessage(\"" + "content" + "\")";                                                             webView.loadUrl(call);

                                               webView.loadUrl("javascript:'"+jsonObject+"'");

                                              Toast.makeText(MainActivity.this, jsonObject.toString(), 

                                                                      Toast.LENGTH_SHORT).show();                                                                           }

                                } 

                      return false;

                }

              @Override

                public void onPageStarted(WebView view, String url, Bitmap favicon) {

                             super.onPageStarted(view, url, favicon);

                }

               @Override

                 public void onPageFinished(WebView view, String url) {

                           super.onPageFinished(view, url);

                   }

     });


代码地址

GitHub - wuzhenmin/work-test-demo

参考资料

developer.android.com/reference/android/webkit/WebView.html

你可能感兴趣的:(webview初识)