美文网首页
webview初识

webview初识

作者: wzmin | 来源:发表于2016-08-05 17:29 被阅读0次

定义   

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

需要的权限

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

<user-permission android:name="android.permission.INTERNET"/>

用法

        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初识

    定义 一个view控件用于加载web页面(目前比较流行的H5页面) 需要的权限 webvi...

  • 初识WebView

    本文目录 1.什么是WebView 2.WebView应用场景2.1 App 内置浏览器2.2 广告2.3 全屏混...

  • 初识WebView控件

    工作需要,学习WebView控件,目前还没有在实际工作中使用,以此作为初识WebView控件的总结。 从《第一行代...

  • (一)初识WebView

    知识预热 Hybrid App 混合开发总是被大家提及,什么是混合开发?其实就是原生(nagtive)+网页(ht...

  • 7月第二周

    7.10 Webview模式初识 mui.fire()自定义事件 dev.dcloud.net.cn/mui/ev...

  • 初识WebView参考的优秀文章

    史上最全WebView使用,附送Html5Activity一份android WebView全面总结Android...

  • WebView·开车指南

    WebView·开车指南 目录 WebView简介 WebView基本使用 WebView常用方法 WebSett...

  • WebView·开车指南

    WebView·开车指南 目录 WebView简介 WebView基本使用 WebView常用方法 WebSett...

  • Android webview访问HTTPS web page如

    WebView myWebView = (WebView) findViewById(R.id.webview);...

  • Android中的WebView详解

    Android中的WebView详解 WebView详解 基本用法 布局文件配置WebView WebView加载...

网友评论

      本文标题:webview初识

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