Injecter du CSS dans un site Web à l'aide de WebView sous Android
Impossible d'injecter du CSS directement dans un site Web affiché via une WebView, il est possible de manipuler le DOM de la page en utilisant JavaScript. Voici comment procéder :
1. Activer JavaScript dans WebView :
<code class="java">webView.getSettings().setJavaScriptEnabled(true);</code>
2. Ajouter un 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. Charger le site Web :
<code class="java">webView.loadUrl("https://www.google.com");</code>
4. Injectez du CSS à l'aide de JavaScript :
<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>
Remarque :
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!