在 Android 中通过 WebView 将 CSS 注入网站
当尝试更改 WebView 中加载的网站的外观时,例如更改将Google.com的背景颜色设置为红色,通过从assets文件夹中注入style.css文件,可能会出现不可预见的错误
提供的代码无法注入style.css文件,因为WebView无法直接访问CSS文件。
解决方案:
注入CSS 到 WebView 中显示的网站中,必须使用基于 JavaScript 的方法:
<code class="java">public class MainActivity extends ActionBarActivity { // Initialize WebView private WebView webView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // Create WebView and enable JavaScript webView = new WebView(this); setContentView(webView); webView.getSettings().setJavaScriptEnabled(true); // Set WebViewClient for page load handling webView.setWebViewClient(new WebViewClient() { @Override public void onPageFinished(WebView view, String url) { // Inject CSS after page load injectCSS(); super.onPageFinished(view, url); } }); // Load the website webView.loadUrl("https://www.google.com"); } // Inject CSS method private void injectCSS() { try { // Retrieve style.css from assets folder InputStream inputStream = getAssets().open("style.css"); byte[] buffer = new byte[inputStream.available()]; inputStream.read(buffer); inputStream.close(); // Encode and insert CSS into HTML document head 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';" + "style.innerHTML = window.atob('" + encoded + "');" + "parent.appendChild(style)" + "})()"); } catch (Exception e) { e.printStackTrace(); } } // ... (Other methods and menus) }</code>
此改进的代码可以实现利用 JavaScript 注入 CSS。它从assets文件夹中读取style.css文件,将其编码为Base64,并将其嵌入到HTML文档头中,从而可以操作网站样式。
以上是如何将 CSS 注入到 Android WebView 中显示的网站中?的详细内容。更多信息请关注PHP中文网其他相关文章!