一、布局相应地方加入WebView控件
<WebView
android:id="@+id/webview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layerType="software">
</WebView>
二、activity中获取控件实例,加载页面
private WebView webView;
String fileUrl="file:///android_asset/lasted_date.html";//要加载的html文件路径
webViewl=findViewById(R.id.webview);
//WebViewUtil为自定义加载类
WebViewUtil.setWebView(webView,fileUrl);
三、WebViewUtil自定义类
package com.example.crab_breeding.first_home.horizontal_menus.statistical_data;
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Toast;
import com.example.crab_breeding.MainActivity;
/**
* 自定义webview加载类
*/
public class WebViewUtil {
/**
* 给webview添加数据
* @param webView
* @param url 要加载的h5文件路径
*/
public static void setWebView(WebView webView, String url) {
WebSettings webSettings = webView.getSettings();
webSettings.setDomStorageEnabled(true);
webSettings.setJavaScriptCanOpenWindowsAutomatically(true);//设置js可以直接打开窗口,如window.open(),默认为false
//如果访问的页面中要与Javascript交互,则webview必须设置支持Javascript
webSettings.setJavaScriptEnabled(true);//是否允许JavaScript脚本运行,默认为false。设置true时,会提醒可能造成XSS漏洞
//webSettings.setSupportZoom(true);//是否可以缩放,默认true
//webSettings.setBuiltInZoomControls(true);//是否显示缩放按钮,默认false
//webSettings.setUseWideViewPort(true);//设置此属性,可任意比例缩放。大视图模式
webSettings.setLoadWithOverviewMode(true);//和setUseWideViewPort(true)一起解决网页自适应问题
webSettings.setAppCacheEnabled(true);//是否使用缓存
webSettings.setDomStorageEnabled(true);//开启本地DOM存储
webSettings.setLoadsImagesAutomatically(true); // 加载图片
//webSettings.setMediaPlaybackRequiresUserGesture(false);//播放音频,多媒体需要用户手动?设置为false为可自动播放
webView.loadUrl(url);
//webView.setWebViewClient(new WebViewClient());
webView.clearCache(true);
webView.setWebChromeClient(new WebChromeClient());
//缓存模式如下:
//LOAD_CACHE_ONLY: 不使用网络,只读取本地缓存数据
//LOAD_DEFAULT: (默认)根据cache-control决定是否从网络上取数据。
//LOAD_NO_CACHE: 不使用缓存,只从网络获取数据.
//LOAD_CACHE_ELSE_NETWORK,只要本地有,无论是否过期,或者no-cache,都使用缓存中的数据。
//不使用缓存,只从网络获取数据。
//webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);
//webView.getSettings().setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);
}
}
四、将要加载的h5文件放入assets文件夹
lasted_data.html文件根据需要撰写,下方内容只是方便测试
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<body>
<div>这是webview加载出来的h5页面。。。</div>
</body>
</html>