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はロードが完了していなくて、空白が発生しました。
解決策:
一つは低バージョンのh 5インターフェースを再設計し、もう一つはプロジェクトの最低バージョンを設定することです。
補足知識:WebView-WebViewを使って順次Urlリストを訪問する。
時々、WebViewを使って、順番にUrlリストを訪問して、ウェブページを更新します。
1.1 WebViewの作成
webView=(WebView)findView ById(R.id.webview)
1.2 WebView設定パラメータ
<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インターフェースの空白が発生しました。つまり、小编が皆さんに共有している内容の全てです。