通常来讲,可能第一时间想到的是自定义一个html来替代webview内置的异常页面。 可是实际操做时,这种方法比较困难。html
这里介绍一个简单的替代方案,但愿能有所帮助。android
能够采用嵌套layout的方式,而后在webview的错WebViewClient的onReceivedError方法中控制异视图的显示和隐藏,具体代码以下:web
public class DefaultWebViewClient extends WebViewClient { boolean isInErrorState = false; @Override public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) { //这里能够将异常信息也显示出来 isInErrorState = true; mEmptyView.setVisibility(View.VISIBLE); webView.setVisibility(View.GONE); mEmptyViewIndicator.setImageResource(R.drawable.no_service); mEmptyView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { isInErrorState = false; webView.reload(); } }); // super.onReceivedError(view, errorCode, description, failingUrl); } @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { if(!isInErrorState) { mEmptyView.setVisibility(View.GONE); webView.setVisibility(View.VISIBLE); }else { mEmptyView.setVisibility(View.VISIBLE); webView.setVisibility(View.GONE); } super.onPageStarted(view, url, favicon); } }
对应的layout以下:ide
<?xml version="1.0" encoding="utf-8"?>url
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"spa
android:orientation="vertical"code
android:layout_width="match_parent"xml
android:layout_height="match_parent">htm
<WebViewblog
android:id="@+id/webView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center_horizontal" />
<LinearLayout
android:orientation="vertical" android:layout_width="match_parent"
android:id="@+id/empty_view_root"
android:layout_height="match_parent"
android:gravity="center"
android:paddingTop="50dp"
android:paddingBottom="50dp">
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/empty_view_indicator"
android:layout_gravity="center"
android:src="@drawable/pic_nothing" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/empty_view_text"
android:textColor="#999999"
android:singleLine="false" />
</LinearLayout>
</RelativeLayout>