在 Android 中使用 WebView 将 CSS 注入到网站中
无法将 CSS 直接注入到通过 WebView 显示的网站中,可以进行操作使用 JavaScript 的页面 DOM。方法如下:
1.在 WebView 中启用 JavaScript:
<code class="java">webView.getSettings().setJavaScriptEnabled(true);</code>
2.添加 WebViewClient:
<code class="java">webView.setWebViewClient(new WebViewClient() { @Override public void onPageFinished(WebView view, String url) { // Inject CSS when page is done loading injectCSS(); super.onPageFinished(view, url); } });</code>
3.加载网站:
<code class="java">webView.loadUrl("https://www.google.com");</code>
4.使用 JavaScript 注入 CSS:
<code class="java">private void injectCSS() { try { InputStream inputStream = getAssets().open("style.css"); byte[] buffer = new byte[inputStream.available()]; inputStream.read(buffer); inputStream.close(); String encoded = Base64.encodeToString(buffer, Base64.NO_WRAP); webView.loadUrl("javascript:(function() {" + "var parent = document.getElementsByTagName('head').item(0);" + "var style = document.createElement('style');" + "style.type = 'text/css';" + // Decode the CSS from BASE64 "style.innerHTML = window.atob('" + encoded + "');" + "parent.appendChild(style)" + "})()"); } catch (Exception e) { e.printStackTrace(); } }</code>
注意:
以上是如何在 Android 中使用 WebView 将自定义 CSS 注入网站?的详细内容。更多信息请关注PHP中文网其他相关文章!