2011-08-09 10 views
4

これは私が従うべきコードです。 onPageFinished(WebViewビュー、String URL)自分のCSSを外部サイトに挿入するために使用しています。残念なことにWebviewでは、ページをレンダリングしてからCSSを適用します。ページをレンダリングするのを待ってから、JavaScriptを表示してから表示されるようにするにはどうすればいいですか?WebViewでCSSを永続化する方法

WebClient HTTPで簡単な方法がありますか?CSSをローカルに取得してリダイレクトしますか?

事前にお寄せいただきありがとうございます。

com.webkitdemo; 

import android.app.Activity; 
import android.os.Bundle; 
import android.os.SystemClock; 
import android.view.View; 
import android.view.Window; 
import android.webkit.WebChromeClient; 
import android.webkit.WebView; 
import android.webkit.WebViewClient; 

public class WebKitDemo extends Activity 
{ 
final Activity activity = this; 

@Override 
public void onCreate(Bundle savedInstanceState) 
{ 
super.onCreate(savedInstanceState); 
this.getWindow().requestFeature(Window.FEATURE_PROGRESS); 
setContentView(R.layout.main); 

//addition final webview 

final WebView webView = (WebView)findViewById(R.id.web_engine); 
/* JavaScript must be enabled if you want it to work, obviously */ 
webView.getSettings().setJavaScriptEnabled(true); 




webView.setWebChromeClient(new WebChromeClient() { 
public void onProgressChanged(WebView view, int progress) 
{ 
activity.setTitle(" Loading..."); 
activity.setProgress(progress * 100); 

if(progress == 100) 
activity.setTitle(R.string.app_name); 
} 
}); 

webView.setWebViewClient(new WebViewClient() { 
@Override 
public void onReceivedError(WebView view, int errorCode, String description, String      failingUrl) 
{ 
// Handle the error 
} 

//additions 

@Override 
public void onPageFinished(WebView view, String url) 
{ 
    webView.loadUrl("javascript:(function() { " + 
     "document.getElementsByTagName('body')[0].style.color = 'green'; " + 
     "})()"); 
} 
// 

@Override 
public boolean shouldOverrideUrlLoading(WebView view, String url) 
{ 
webView.loadUrl(url); 
return true; 
} 



}); 
webView.loadUrl("http://code.google.com"); 
}} 

答えて

-1

スタイルを変更する前にこれを追加してください。そうすれば、ページの読み込みが完了したときにのみ実行されます。

var oldonload = window.onload; 
if (typeof window.onload != 'function') 
    { 
    window.onload = yourfunctionhere(); 
    } 
else 
    { 
    window.onload = function() 
    { 
    yourfunctionhere(); 
    oldonload(); 
    } 
}