首页  >  文章  >  web前端  >  如何在 Android 中使用 WebView 将自定义 CSS 注入网站?

如何在 Android 中使用 WebView 将自定义 CSS 注入网站?

Susan Sarandon
Susan Sarandon原创
2024-11-01 06:21:31108浏览

How to Inject Custom CSS into a Website Using WebView in Android?

在 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>

注意:

  • style.css 文件应位于项目的 asset 文件夹中。
  • webView.loadUrl() 方法必须在 onPageFinished() 回调之后调用,因为在页面加载之前注入 CSS 不会有任何效果。

以上是如何在 Android 中使用 WebView 将自定义 CSS 注入网站?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn