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);

}

}

“`

以上示例只是一個簡單的封裝網頁的實現,實際應用中可能需要更復雜的實現方式。總的來說,封裝網頁可以提高應用程序的用戶體驗和自定義性,同時也需要考慮到一些安全和性能問題。

未經允許不得轉載:智電網絡 NET » android 封裝網頁操作步驟介紹

相關推薦