Javascript WebView.loadUrl()中的Android JS
我想在WebView中加载网页,但删除部分网页。因此,我创建了一个自定义WebViewClient。在onPageFinished()中,我使用了一些javascript来删除一些元素。然后,我使WebView可见 但是,当我运行它时,它会将视图设置为可见,然后我会看到元素被删除。这就好像JS在后台运行得非常慢。它创建了一个糟糕的观看体验,因为它会闪烁整个页面,然后是所需的部分页面 这是我的onPageFinished()Javascript WebView.loadUrl()中的Android JS,javascript,android,android-webview,webviewclient,Javascript,Android,Android Webview,Webviewclient,我想在WebView中加载网页,但删除部分网页。因此,我创建了一个自定义WebViewClient。在onPageFinished()中,我使用了一些javascript来删除一些元素。然后,我使WebView可见 但是,当我运行它时,它会将视图设置为可见,然后我会看到元素被删除。这就好像JS在后台运行得非常慢。它创建了一个糟糕的观看体验,因为它会闪烁整个页面,然后是所需的部分页面 这是我的onPageFinished() 关于如何解决此问题,您有什么想法吗?您可以尝试通过以下方式加快您的网络视
关于如何解决此问题,您有什么想法吗?您可以尝试通过以下方式加快您的网络视图速度:
webview.getSettings().setRenderPriority(RenderPriority.HIGH);
webview.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);
无论如何,你不应该马上让你的网络视图可见。为什么不创建一个接口(参见,将JavaScript代码绑定到Android)并从JavaScript调用:
public void myCallback(){ view.SetVisibilitu(View.VISIBLE) };
动画结束后?在onPageFinished()中:
在MainActivity.onCreate()中:
在MainActivity()中:
因此,它是制作JavascriptInterface和制作JS函数的组合,在调用接口之前等待JS调用完成(使用可见性设置)。我刚刚尝试制作接口,但在JS完成之前,它仍然可见。我遵循:我自己不是js专家,但在更改样式后尝试使用setTimeout(yourAndroidCallbackFunction,5000),看看这是否是问题所在。效果非常好。非常感谢。
public void myCallback(){ view.SetVisibilitu(View.VISIBLE) };
view.loadUrl("javascript:"
+ "var FunctionOne = function () {"
+ " var r = $.Deferred();"
+ " try{document.getElementsByClassName('header')[0].style.display='none';}catch(e){}"
+ " try{document.getElementById('section_0').style.display='none';}catch(e){}"
+ " try{document.getElementById('page-actions').style.display='none';}catch(e){}"
+ " try{document.getElementsByClassName('languageSelector')[0].style.display='none';}catch(e){}"
+ " try{document.getElementById('mw-mf-last-modified').style.display='none';}catch(e){}"
+ " try{document.getElementById('footer').style.display='none';}catch(e){}"
+ " setTimeout(function () {"
+ " r.resolve();"
+ " }, 2500);"
+ " return r;"
+ "};"
+ "var FunctionTwo = function () {"
+ " window.CallToAnAndroidFunction.setVisible();"
+ "};"
+ "FunctionOne().done(FunctionTwo);");
this.webView.addJavascriptInterface(new JsObject(webView, loadingView), "CallToAnAndroidFunction");
public class JsObject {
private View loadingView;
private View view;
JsObject(View view, View loadingView){this.view = view;this.loadingView = loadingView;}
@JavascriptInterface
public void setVisible(){
runOnUiThread(new Runnable() {
@Override
public void run() {
view.setVisibility(View.VISIBLE);
loadingView.setVisibility(View.INVISIBLE);
}
});
}
}