WebViewはURLを通じてH 5インターフェースをロードして空白が発生する問題を解決します。


1.パーミッション問題:プロファイルにネットワーク権限を設定する必要があります。
<uses-permission android:name=「android.permission.INTERNET」/>
2.基本配置の問題
WebSettings web Settings=webView.get Settings()//ズームをサポートします。デフォルトはtrueです。
setUseWideviewPort(true)//スクリーンのサイズに合わせる
set LoadWithOverview Mode(true)//デフォルトのエンコーディングを設定します
webSettings.set Default Text EncoccodingName("utf-8")///////////。画像の自動読み込みの設定
web Settings.set Loads Images Automaticaly(true)
settings.set JavaScript Enbaled(true)//JSスクリプトを実行できるように設定します。
settings.set SupportZoom(false)//webviewの拡大設定に使用します。
settings.set BuiiltInZoomControls(false)
3.Uncaght TypeError:Canot call method'getItem'of null異常が発生しました。
この行は異常が発生しました。これはhttml 5の特性です。ローカルに格納されているものの一つは、cookieよりも記憶量が大きいです。しかし、これはandroidのwebviewでコードで起動しなければなりません。
解決方法:webviewのhtml 5のローカルストレージ機能を起動します。
webview.get Settings().set Dom StrageEnbaled(true)
webview.get Settings().setApple CacheMaxSize(1024*1024*8)
String appcachePath=getAppliationConttext().getCacheDir().getAbsolute Path()
webview.get Settings()setApp CachePath;
webview.get Settings()set AllowFileAccess(true)
webview.get Settings().setApple CacheEnballd(true)
4.get DeviceIDメソッドを呼び出した時、jsはロードが完了していなくて、空白が発生しました。
解決策:

webview.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}

@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
//          js  
if(!flag_get_deviceid){
load();
}
}

@Override
public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
super.onReceivedError(view, errorCode, description, failingUrl);
}

});

private boolean flag_get_deviceid=false;
public void load(){
String key="";
String androidID="";
try{
androidID = Secure.getString(getContentResolver(),Secure.ANDROID_ID);
Log.d(TAG, "androidID:"+androidID);}catch(Exception e){
Log.e(TAG, "");
}finally{
String script=String.format("javascript:getDeviceID('"+androidID+"')");
webActDetail.evaluateJavascript(script, new ValueCallback<String>() {

@Override
public void onReceiveValue(String value) {
Log.d(TAG, "onReceiveValue value=" + value);

if(value!=null){
flag_get_deviceid=true;
}
}});
}
}
5.androidの携帯電話のバージョンの問題は、現在H 5のインターフェースが多様化しており、多くのH 5インターフェースが低バージョンの機種では展示できなくなりました。
一つは低バージョンのh 5インターフェースを再設計し、もう一つはプロジェクトの最低バージョンを設定することです。
補足知識:WebView-WebViewを使って順次Urlリストを訪問する。
時々、WebViewを使って、順番にUrlリストを訪問して、ウェブページを更新します。
1.1 WebViewの作成
webView=(WebView)findView ById(R.id.webview)
1.2 WebView設定パラメータ

  //     
  webView.getSettings().setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);
  //      
  // webView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);
  //     
  webView.clearCache(true);
  //       
  webView.clearHistory();
  //   cookies
  CookieSyncManager.createInstance(this);
  CookieSyncManager.getInstance().startSync();
  CookieManager.getInstance().removeSessionCookie();
  //         
  webView.getSettings().setSupportZoom(true);
  //         
  webView.getSettings().setBuiltInZoomControls(true);
  webView.getSettings().setJavaScriptEnabled(true);
1.3 Urlリストを取得する

int index = 0;
 
String [] strList = new String[]{"https://www.jb51.net",
"https://www.jd.com","https://www.csdn.net",https://www.baidu.com};
1.4 WebView設定WebView Cient

//     WebViewClient
  webView.setWebViewClient(new WebViewClient() {
   @Override
   public void onPageFinished(WebView view, String url) {
    super.onPageFinished(view, url);
    index++;
    if(index>artStr.length){
 
    }else {
     webView.clearCache(true);
     webView.clearView();
     Log.i("===onPageFinished====", index + "=======");
     refreshWebpage(index);
    }
   }
  });
1.5 WebViewローディング

 public void refreshWebpage(int index) {
  String csdnStr = urlStr + artStr[index];
 
  //     url
  webView.loadUrl(csdnStr);
 }
以上のWebViewはURLを通じてH 5インターフェースの空白が発生しました。つまり、小编が皆さんに共有している内容の全てです。