Android에서 WebView를 사용하여 웹사이트에 CSS 삽입
WebView를 통해 표시되는 웹사이트에 CSS를 직접 삽입할 수 없으므로 조작이 가능합니다. 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!