(一)使用中遇到的问题:

1、解决webview缓存: WebSettings.LOAD_NO_CACHE   或者直接清除缓存

webView.getSettings().setCatchMode(WebSettings.LOAD_NO_CATCH);

2、解决webview无法弹出alert: WebChromeClient中重写onJsAlert方法

3、解决webview获取网页内容“: addJavascriptInterface(new InJavaScriptLocalObj(), "local_obj")

(二)webview组件如何使用:

添加权限:AndroidManifest.xml中必须使用许可"android.permission.INTERNET",否则会出Web page not available错误。

在要Activity中生成一个WebView组件:WebView webView = new WebView(this);或者可以在activity的layout文件里添加webview控件:

<WebView

android:id="@+id/wv"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:text="@string/hello"/>

(三)设置WebView基本信息

/**
  * 显示WebView
  */
 public void showWebView(String url){
     webview.getSettings().setJavaScriptEnabled(true);  //  设置页面支持Javascript
     webview.getSettings().setLoadWithOverviewMode(true);
     webview.getSettings().setSupportZoom(true);          //支持缩放
     webview.getSettings().setBuiltInZoomControls(true); //显示放大缩小
     webview.setInitialScale(130); //初始化时缩放
     webview.getSettings().setDefaultTextEncodingName("utf-8"); 
      webview.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);//解决缓存问题
     webview.loadUrl(url);
     
     webview.addJavascriptInterface(new InJavaScriptLocalObj(), "local_obj");//获取网页内容
     webview.setWebViewClient(new MyWebViewClient());
     webview.setWebChromeClient(new HellowebViewClient());
 }
 
 final class InJavaScriptLocalObj {  //获取网页内容
        public void showSource(String html) { 
           // Log.d("HTML", html);        
            if((html != null && html.contains("重新登录")) || (html != null && html.contains("nologin.jsp"))) {
             Log.d("TAG", "重新登录");
             Toast.makeText(getApplicationContext(), "获取信息失败,请重新访问", 0).show();
            }
        } 
    }
 
 /**
  * 解决webview中当开启新的页面的时候用webview来进行处理而不是用系统自带的浏览器处理
  *
  * 载入页面完成的事件,获取网页内容
  * @author Administrator
  *
  */
 private class MyWebViewClient extends WebViewClient {
  /**
   *  如果希望点击链接由自己处理,而不是新开Android的系统browser中响应该链接。
   *  给WebView添加一个事件监听对象(WebViewClient)并重写其中的一些方法:
    * shouldOverrideUrlLoading:对网页中超链接按钮的响应。当按下某个连接时
    * WebViewClient会调用这个方法,并传递参数:按下的url。比如当webview内嵌
    *  网页的某个数字被点击时,它会自动认为这是一个电话请求,会传递url:tel:123,
    *  如果你不希望如此可通过重写shouldOverrideUrlLoading函数解决
   */
  @Override
  public boolean shouldOverrideUrlLoading(WebView view, String url) {
      // 当开启新的页面的时候用webview来进行处理而不是用系统自带的浏览器处理
   // 互联网用:webView.loadUrl("http://www.google.com");
         // 本地文件用:webView.loadUrl("file:///android_asset/XX.html");  本地文件存放
            view.loadUrl(url); 
   return true;
  }
  
  /**
  *载入页面完成的事件
  **/
  @Override
  public void onPageFinished(WebView view, String url) {
   //获取网页内容
   view.loadUrl("javascript:window.local_obj.showSource" +
     "('<head>'+document.getElementsByTagName('html')[0].innerHTML+'</head>');");
   super.onPageFinished(view, url);
  } 
  
 }
 /***************************************************/
 
 /**
  * 解决webview中无法弹出alert的问题
  */
 private class HellowebViewClient extends WebChromeClient {
  @Override
  public boolean onJsAlert(WebView view, String url, String message,
       final JsResult result) {
         AlertDialog.Builder b2 = new AlertDialog.Builder(Test.this)
                  .setTitle("提示:").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;
     }
 }
 /*
 1,接收到Http请求的事件
 onReceivedHttpAuthRequest(WebView view, HttpAuthHandler handler, String host, String realm)
 2,打开链接前的事件
 public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true; }
 这个函数我们可以做很多操作,比如我们读取到某些特殊的URL,于是就可以不打开地址,取消这个操作,进行预先定义的其他操作,这对一个程序是非常必要的。
 
 3,载入页面完成的事件
 public void onPageFinished(WebView view, String url){ }
 同样道理,我们知道一个页面载入完成,于是我们可以关闭loading条,切换程序动作。
 
 4,载入页面开始的事件
 public void onPageStarted(WebView view, String url, Bitmap favicon) { }
 这个事件就是开始载入页面调用的,通常我们可以在这设定一个loading的页面,告诉用户程序在等待网络响应。
 */

(四)WebView基础

WebView是android.webkit包下的一个组件,能用来显示网页。

WebView默认是不带地址栏和加载进度条的,单单是一个显示页面内容的面板。

使用WebView非常简单,主要是通过load方法进行加载。

[使用WebView打开一个网页] 1.在布局xml文件中定义WebView组件 < WebView  android:id = "@+id/webview"      android:layout_width = "match_parent"      android:layout_height = "match_parent" />

2.在AndroidManifest.xml中添加网络访问权限 <

uses-permission

android:name

=

"android.permission.INTERNET"

/ >

3.通过load函数加载网页

mWebview = (WebView) this .findViewById(R.id. webview  ); // 简单地加载一个页面

mWebview .loadUrl(url); //  加载assets目录下的页面(assetsindex.html)

mWebview .loadData( "file:///android_asset/index.html"  );

但你会发现,如果点击页面的某条链接进行跳转的话,会启动系统的默认浏览器进行加载,调出了我们本身的应用。要解决这个问题我们需要借助于WebViewClient。

[自定义链接的跳转显示]

mWebview .setWebChromeClient( new WebViewClient()  {

public  boolean  shouldOverrideUrlLoading(WebView  view, String  url){             //  使用当前的WebView加载页面

view.loadUrl(url);

return  true ;

}

});

在WebViewClient中还有很多的方法,例如: public  void  onPageStarted(WebView view, String url, Bitmap favicon);

public  void  onPageFinished(WebView view,  String url);

public  void  onLoadResource(WebView view,  String url)

public  void  onReceivedError(WebView  view,  int  errorCode, String description, String  failingUrl)

我们都可以通过重写来实现自己的个性化操作。

[页面回退] 实现了跳转后,你忽然想返回到前一个浏览过的页面是,发现返回键是直接退出应用了。要实现类似系统浏览器那样的,返回键先是返回到上一个页面,直到最初始的页面才退出的话,可以这么做:

//  重写onKeyDown

public  boolean  onKeyDown (  int  keyCode, KeyEvent event) {

if  ((keyCode == KeyEvent. KEYCODE_BACK ) &&  mWebview .canGoBack())  {

mWebview  .goBack();

return  true ;

}

return  super .onKeyDown(keyCode, event);

}

[进度条] 要是再加上加载进度条那就完美了,我们可以借助WebChromeClient来实现:

mWebview  .setWebChromeClient( new WebChromeClient()  {

public  void  onProgressChanged (WebView view,  int  newProgress){

loadingProgress .setProgress(newProgress);

}

});

android 之WebView的更多相关文章

  1. Android中webView和网页的交互

     Android中webView和网页的交互 Android中webView跟网页的交互式通过JavaScript进行的.具体步骤: 1.创建JavaScript,在点击的时候调用JavaScript ...

  2. Android 显示 WebView ,加载URL 时,向webview的 header 里面传递参数

    1.主要布局 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:and ...

  3. Android中Webview使用自定义的javascript进行回调

    先说为什么需要讨论这个问题. 现在很多的手机应用,都可能会直接嵌入一个web页面.这样做的好处:一个是功能更新方便,维护起来容易,只需要维护服务器的页面即可,不需要更新客户端:另一个是功能通用,不仅a ...

  4. android使用Webview上传图片

    package com.example.webview; import java.io.File; import android.net.Uri;import android.os.Bundle;im ...

  5. Android之 -WebView实现离线缓存阅读

    前言 本篇博客要实现的是一个离线下载和离线阅读的功能,这是很多阅读类app都常见的一个功能,典型的应用就是网易新闻.什么是离线下载?其实这个概念是比较模糊,是离线之后下载呢,还是下载之后离线,但稍微有 ...

  6. 在Android的webview中定做js的alert,confirm和prompt对话框的方法

    在Android的webview中定制js的alert,confirm和prompt对话框的方法 http://618119.com/archives/2010/12/20/199.html 1.首先 ...

  7. Android 响应webview中图片的点击事件

    最近碰到个新需求需要点击webview中的图片进行放大显示. 整理了下思路,想到了下面的一个可行的方案. 方案思路, 1.在点击图片的时候调用本地的java方法并给出响应的图片地址 2.本地获得图片地 ...

  8. android利用WebView实现浏览器的封装

    android提供了封装浏览器的接口,可以让开发者利用自己的view显示网页内容.今天又实现研究了一下,利用WebView显示浏览器内容,还可以利用 WebViewClient显示自己需要的内容. 参 ...

  9. [原][Android]All WebView methods must be called on the same thread.

    问题 webView调用JS出错. class TestJS {         ......         public TestJS(){         }                   ...

  10. android使用webview加载flash文件

    android 字段webview几乎实现了浏览器的全部功能,最近在使用webview加载不固定格式的文章,文章中有一部分嵌入了flash,下面就是webview可以进行视频需要进行的设置,代码如下: ...

随机推荐

  1. 并发编程学习笔记(9)----AQS的共享模式源码分析及CountDownLatch使用及原理

    1. AQS共享模式 前面已经说过了AQS的原理及独享模式的源码分析,今天就来学习共享模式下的AQS的几个接口的源码. 首先还是从顶级接口acquireShared()方法入手: public fin ...

  2. CAD与用户交互在图面上选择一个实体(com接口VB语言)

    主要用到函数说明: IMxDrawUtility::GetEntity 与用户交互到在图面上选择一个实体,详细说明如下: 参数 说明 [out] IMxDrawPoint** pPickPoint 返 ...

  3. 15 AJAX

     AJAX AJAX 简介 AJAX 是 异步 JavaScript 及 XML(Asynchronous JavaScript and XML)的缩写.AJAX 不是一种新的编程语言,而是一种用于创 ...

  4. 写给新手的十一条 Docker 守则

    很多人最终还是决定使用 Docker 解决问题. Docker 的优点很多,比如: 一体化——将操作系统.库版本.配置文件.应用程序等全部打包装在容器里.从而保证 QA 所测试的镜像 (image) ...

  5. Eureka组件、Eureka自我保护模式

    Eureka包含两个组件:Eureka Server和Eureka Client   Eureka Server提供服务发现的能力,各个微服务启动时,会向Eureka Server注册自己的信息(例如 ...

  6. springAOP源码解析-190313

    Spring相关笔记 SpringAOP讲解 子路老师讲解 spring与aspectj的区别答:它们的区别是 spring是动态加载 aspectj是静态加载,再编译过程就已经实现切面,此时会往代码 ...

  7. 07Html、CSS

    07Html.CSS-2018/07/17 1.HTML是用来描述网页的一种标记语言,是一套标记标签.HTML用使用标记标签来描述网页.超文本 标记语言. 2.格式 <html> < ...

  8. JavaScript--小白入门篇3

    一.函数 1.1 初步认识函数 1 <script type="text/javascript"> 2 console.log("你好"); 3 s ...

  9. MySql报Packet for query is too large错误

    mysql中执行sql的时候报以下错误:Packet for query is too large (1354 > 1024) 原因是mysql一次接收的报文太长,需要调整服务器参数max_al ...

  10. python之cookbook-day01

    第一章:数据结构和算法 1.1 解压序列赋值给多个变量 >>> p = (4, 5) >>> x, y = p >>> x 4 >>& ...