溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

WebView中通過URL加載H5界面出現(xiàn)空白如何解決

發(fā)布時間:2021-06-12 17:53:01 來源:億速云 閱讀:485 作者:Leah 欄目:移動開發(fā)

WebView中通過URL加載H5界面出現(xiàn)空白如何解決,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

1.權限問題:在配置文件中需要設置網(wǎng)絡權限

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

2.基本配置問題

WebSettings webSettings = webView.getSettings(); //支持縮放,默認為true。

.setUseWideViewPort(true); // 縮放至屏幕的大小 webSettings

.setLoadWithOverviewMode(true); //設置默認編碼

webSettings .setDefaultTextEncodingName("utf-8"); ////設置自動加載圖片

webSettings .setLoadsImagesAutomatically(true);

.settings.setJavaScriptEnabled(true);// 設置可以運行JS腳本
.settings.setSupportZoom(false);// 用于設置webview放大
.settings.setBuiltInZoomControls(false);

3.出現(xiàn)Uncaught TypeError: Cannot call method 'getItem' of null異常

這個行出現(xiàn)了異常,這個正是html5的特性,一個本地存儲的東西,存儲量比cookie大,但是這個必須在android的webview用代碼啟動才行

解決方法:啟動webview的html5的本地存儲功能。

webview.getSettings().setDomStorageEnabled(true);

webview.getSettings().setAppCacheMaxSize(1024*1024*8);

String appCachePath = getApplicationContext().getCacheDir().getAbsolutePath();

webview.getSettings().setAppCachePath(appCachePath);

webview.getSettings().setAllowFileAccess(true);

webview.getSettings().setAppCacheEnabled(true);

4.調用getDeviceID 方法的時候,js沒有加載完畢,導致出現(xiàn)空白

解決辦法:

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);
//在這里執(zhí)行你想調用的js函數(shù)
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手機版本問題,現(xiàn)在H5界面實現(xiàn)多樣化,導致很多H5界面在低版本的機型上無法展示或者樣式錯亂

解決辦法:一種是重新設計低版本的h6界面,另一種設置項目最低版本

補充知識:WebView-使用WebView依次訪問Url列表

有時候,我們需要使用WebView依次訪問Url列表,來刷新網(wǎng)頁;

1.1 WebView創(chuàng)建

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

1.2 WebView設置參數(shù)

  // 設置緩存
  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);
  // 設置出現(xiàn)縮放工具
  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設置WebViewClient

// 直接創(chuàng)建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加載Url

 public void refreshWebpage(int index) {
  String csdnStr = urlStr + artStr[index];
 
  // 直接調用url
  webView.loadUrl(csdnStr);
 }

看完上述內容,你們掌握WebView中通過URL加載H5界面出現(xiàn)空白如何解決的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI