2011-08-09 35 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(); 
    } 
}