android-WebView使用

一、WebView简单介绍

WebView可以当做一个浏览网页使用,使用的是WebKit渲染加载的。

1、声明布局

<WebView
    android:id="@+id/mWebView"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />  

2、简单使用

mWebView = (WebView) findViewById(R.id.mWebView);
mWebView.loadUrl("http://www.baidu.com/");

二、具体使用

使用上述会发现可以简单加载出网页,但是一些图片,布局还是有问题,所以需要进行相关的设置,其中主要的流程mWebView->webSettings->webClient

1、网络权限

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

2、进行WebSettings类的相关设置

//声明WebSettings子类
WebSettings webSettings = webView.getSettings();

//如果访问的页面中要与Javascript交互,则webview必须设置支持Javascript,开启后
webSettings.setJavaScriptEnabled(true);  
mWebview.getSettings().setBlockNetworkImage(false);//解决图片不显示
//注意此问题,android5.0后不允许Https与Http混用,所以要区分设置,
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {  
     webView.getSettings().setMixedContentMode(WebSettings.MIXED_CONTENT_ALWAYS_ALLOW);  
} 
//支持插件
webSettings.setPluginsEnabled(true); 

//设置自适应屏幕,两者合用
webSettings.setUseWideViewPort(true); //将图片调整到适合webview的大小 
webSettings.setLoadWithOverviewMode(true); // 缩放至屏幕的大小

//缩放操作
webSettings.setSupportZoom(true); //支持缩放,默认为true。是下面那个的前提。
webSettings.setBuiltInZoomControls(true); //设置内置的缩放控件。若为false,则该WebView不可缩放
webSettings.setDisplayZoomControls(false); //隐藏原生的缩放控件

//其他细节操作
webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); //关闭webview中缓存 
webSettings.setAllowFileAccess(true); //设置可以访问文件 
webSettings.setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口 
webSettings.setLoadsImagesAutomatically(true); //支持自动加载图片
webSettings.setDefaultTextEncodingName("utf-8");//设置编码格式

设置WebView缓存

  • 当加载 html 页面时,WebView会在/data/data/包名目录下生成 database 与 cache 两个文件夹
  • 请求的 URL记录保存在 WebViewCache.db,而 URL的内容是保存在 WebViewCache 文件夹下
  • 是否启用缓存:
//优先使用缓存: 
    WebView.getSettings().setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); 
        //缓存模式如下:
        //LOAD_CACHE_ONLY: 不使用网络,只读取本地缓存数据
        //LOAD_DEFAULT: (默认)根据cache-control决定是否从网络上取数据。
        //LOAD_NO_CACHE: 不使用缓存,只从网络获取数据.
        //LOAD_CACHE_ELSE_NETWORK,只要本地有,无论是否过期,或者no-cache,都使用缓存中的数据。

    //不使用缓存: 
    WebView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);

3、进行WebClient设置

这一个类中设置的主要是几个,

一个是shouldOverrideUrlLoading控制不调用系统浏览器(旧方法已经在API26的时候不建议使用了)

//步骤1. 定义Webview组件
Webview webview = (WebView) findViewById(R.id.webView1);

//步骤2. 选择加载方式
  //方式1. 加载一个网页:
  webView.loadUrl("http://www.google.com/");

  //方式2:加载apk包中的html页面
  webView.loadUrl("file:///android_asset/test.html");

  //方式3:加载手机本地的html页面
   webView.loadUrl("content://com.android.htmlfileprovider/sdcard/test.html");

//步骤3. 复写shouldOverrideUrlLoading()方法,使得打开网页时不调用系统浏览器, 而是在本WebView中显示
    webView.setWebViewClient(new WebViewClient(){
      @Override
      public boolean shouldOverrideUrlLoading(WebView view,WebResourceRequest request) {
          view.loadUrl(request.getUrl().toString());
      return true;
      }
  });

goback控制按返回键的时候是返回上一层还是直接退出

mWebView.setOnKeyListener(new View.OnKeyListener() {
    @Override
    public boolean onKey(View v, int keyCode, KeyEvent event) {
        if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) {
            // 返回键退回
            mWebView.goBack();
            return true;
        } else
            return false;
    }
});

onPageStarted()作用:开始载入页面调用的,我们可以设定一个loading的页面,告诉用户程序在等待网络响应。

webView.setWebViewClient(new WebViewClient(){
      @Override
      public void  onPageStarted(WebView view, String url, Bitmap favicon) {
         //设定加载开始的操作
      }
  });

onPageFinished()作用:在页面加载结束时调用。我们可以关闭loading 条,切换程序动作。

 webView.setWebViewClient(new WebViewClient(){
      @Override
      public void onPageFinished(WebView view, String url) {
         //设定加载结束的操作
      }
  });

其他方法:

onReceivedError 报告错误信息 
onLoadResource 加载指定地址提供的资源 
doUpdate VisitedHistory 更新历史记录 
onFormResubmission 应用程序重新请求网页数据 
onScaleChanged WebView发生改变

4、进行WebChromeClient设置

主要是与Js进行交互,因为没使用,不过多赘述,可参考

onProgressChanged 加载进度条改变 
onJsPrompt 用在解决4.2以下addJavascriptInterface漏洞问题 
onCloseWindow 关闭WebView 
onCreateWindow 创建WebView 
onJsAlert 处理Javascript中的Alert对话框 
onJsConfirm处理Javascript中的Confirm对话框 
onJsPrompt处理Javascript中的Prompt对话框 
onReceivedlcon 网页图标更改 
onReceivedTitle 网页Title更改 
onRequestFocus WebView显示焦点 
onConsoleMessage 在Logcat中输出javascript的日志信息

5、避免WebView内存泄漏

1)、不再xml中设置WebView,而是在代码中实现,传入ApplicationContect

LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);
        mWebView = new WebView(getApplicationContext());
        mWebView.setLayoutParams(params);
        mLayout.addView(mWebView);
2)、  在 Activity 销毁( WebView )的时候,先让 WebView 加载null内容,然后移除 WebView,再销毁 WebView,最后置空
@Override
    protected void onDestroy() {
        if (mWebView != null) {
            mWebView.loadDataWithBaseURL(null, "", "text/html", "utf-8", null);
            mWebView.clearHistory();

            ((ViewGroup) mWebView.getParent()).removeView(mWebView);
            mWebView.destroy();
            mWebView = null;
        }
        super.onDestroy();
    }


可参考: http://blog.csdn.net/kui2015/article/details/52249262
             http://blog.csdn.net/carson_ho/article/details/52693322







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Android Studio中使用WebView的步骤如下: 1. 在布局文件中添加WebView组件: ``` <WebView android:id="@+id/webview" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 2. 在Activity中获取WebView组件的引用: ``` WebView webView = (WebView) findViewById(R.id.webview); ``` 3. 设置WebView的属性,如启用JavaScript、缩放等: ``` webView.getSettings().setJavaScriptEnabled(true); webView.getSettings().setBuiltInZoomControls(true); ``` 4. 加载网页: ``` webView.loadUrl("http://www.example.com"); ``` 5. 处理WebView的各种事件,如页面加载完成、页面加载失败等: ``` webView.setWebViewClient(new WebViewClient() { @Override public void onPageFinished(WebView view, String url) { // 页面加载完成 } @Override public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) { // 页面加载失败 } }); ``` 以上就是使用Android Studio中WebView的基本步骤。 ### 回答2: Android Studio是开发Android应用程序的集成开发环境(IDE)。其中一个常见的功能是使用WebView来显示Web内容。WebView是Android中的内置组件,可用于在应用程序中显示Web页面。这对于需要整合Web和本地应用程序的开发人员来说非常有用。 使用WebView在应用程序中显示Web页面的过程包括以下步骤: 1.在布局文件中添加WebView元素:在布局文件中添加一个WebView元素。例如: <WebView android:id="@+id/web_view" android:layout_width="match_parent" android:layout_height="match_parent" /> 2.在Java代码中为WebView加载URL:在Java代码中为WebView加载URL。例如: WebView webView = (WebView) findViewById(R.id.web_view); webView.loadUrl("http://www.example.com/"); 3.自定义WebView设置:根据需要,可以使用WebView类的各种设置进行自定义。例如: webView.getSettings().setJavaScriptEnabled(true); webView.getSettings().setJavaScriptCanOpenWindowsAutomatically(true); webView.getSettings().setBuiltInZoomControls(true); webView.getSettings().setDisplayZoomControls(false); webView.setWebViewClient(new WebViewClient()); 4.处理WebView中的链接:处理WebView中的链接通常需要添加WebViewClient。例如: webView.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { if (url.startsWith("http:") || url.startsWith("https:")) { view.loadUrl(url); return false; } // Handle other URL schemes return true; } }); 这些步骤的组合可以帮助您在Android应用程序中轻松使用WebView。如果您想更深入地学习WebView的使用,可以探索WebView类的其他方法和WebViewClient类的功能。 ### 回答3: Android Studio是一个功能强大的开发工具,可以用于Android App的开发。而使用WebView是在Android应用中显示网页内容的常用方式。WebView是Android中自带的一个View,可以将它作为一个控件嵌入应用程序中,以显示Web页面。 WebView的使用方法如下: 1. 在布局文件中添加WebView控件: ``` <WebView android:id="@+id/webview" android:layout_width="match_parent" android:layout_height="match_parent"/> ``` 2. 在Java代码中获取WebView控件的实例,并使用loadUrl()方法加载需要显示的网页: ``` WebView webView = (WebView) findViewById(R.id.webview); webView.loadUrl("http://www.example.com/"); ``` 3. 如果需要细致地控制WebView的行为,可以使用WebSettings类来进行设置。例如设置支持JavaScript: ``` WebSettings webViewSettings = webView.getSettings(); webViewSettings.setJavaScriptEnabled(true); ``` 4. WebView也支持处理一些与网页有关的事件。例如,当WebView加载完毕时,调用onPageFinished()方法: ``` webView.setWebViewClient(new WebViewClient() { @Override public void onPageFinished(WebView view, String url) { // Do something when page is finished loading } }); ``` 5. 如果需要拦截WebView中的请求并进行处理,可以使用WebViewClient类的shouldOverrideUrlLoading()方法: ``` webView.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { // Do something when a url is clicked inside the WebView return true; // Return true to indicate the click has been handled } }); ``` 总而言之,WebView是一个非常便捷的控件,使得在Android应用程序中显示网页内容非常易于操作。通过加入一些简单的设置和事件处理,可以在应用程序中提供完整的Web浏览体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值