ttings();
webSettings.setJavaScriptEnabled(true);
h5打包ios上架 webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);
setWebViewClient(new MyWebViewClient());
setWebChromeClient(new MyWebChromeClient());
}
public void loadUrlWithHeader(String url, Map headers) {
if (url == null) {
return;
}
if (headers == null || headers.isEmpty()) {
loadUrl(url);
return;
}
String cookie = headers.get(“Cookie”);
if (!TextUtils.isEmpty(cookie)) {
CookieManager.getInstance().setCookie(url, cookie);
}
String userAgent = headers.get(“User-Agent”);
if (!TextUtils.isEmpty(userAgent)) {
getSettings().setUserAgentString(userAgent);
}
loadUrl(url);
}
public void showToast(String message) {
Toast.makeText(getContext(), message, Toast.LENGTH_SHORT).show();
}
public void setIsSupportZoom(boolean flag) {
isSupportZoom = flag;
getSettings().setSupportZoom(flag);
}
private class MyWebViewClient extends WebViewClient {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
if (url.startsWith(“http://”) || url.startsWith(“https://”)) {
view.loadUrl(url);
return true;
}
return false;
}
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
// 頁面開始加載
}
@Override
public void onPageFinished(WebView view, String url) {
// 頁面加載完成
}
@Override
public void onReceivedError(WebView view, WebResourceRequest request, WebResourceError error) {
// 頁面加載失敗
}
}
private class MyWebChromeClient extends WebChromeClient {
@Override
public boolean onJsAlert(WebView view, String url, String message, JsResult result) {
// 彈出對話框
return true;
}
@Override
public void onProgressChanged(WebView view, int newProgress) {
// 顯示進度條
}
}
}
“`
2. 在MyWebView的外部封裝一些常用的方法,例如loadUrl(String url),用于加載指定的url地址的網頁,同時可以通過調用MyWebView的相關方法來控制網頁的行為和交互。
“`
public class WebViewActivity extends AppCompatActivity {
private MyWebView mWebView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_web_view);
mWebView = findViewById(R.id.web_view);
mWebView.setIsSupportZoom(false);
mWebView.loadUrl(“https://www.baidu.com”);
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_BACK && mWebView.canGoBack()) {
mWebView.goBack();
return true;
}
return super.onKeyDown(keyCode, event);
}
}
“`
以上示例只是一個簡單的封裝網頁的實現,實際應用中可能需要更復雜的實現方式。總的來說,封裝網頁可以提高應用程序的用戶體驗和自定義性,同時也需要考慮到一些安全和性能問題。