内容简介:注意: js调用android时的安全性(addJavascriptInterface):
- 1.通过WebView的loadUrl()
- 2.通过WebView的evaluateJavascript()
public static void runJsFunc(WebView webView,String funcName,@Nullable ValueCallback<String> callback, Object... params){
if(TextUtils.isEmpty(funcName)){
return;
}
if(webView == null){
return;
}
StringBuilder builder = new StringBuilder(funcName);
builder.append("(");
if(params != null && params.length >0){
int len = params.length;
for (int i = 0; i<len; i++){
Object param = params[i];
String str = "";
if(param != null){
if(param instanceof String){
str = "\""+param.toString()+"\"";
}else {
str = param.toString();
}
}
builder.append(str);
if(i != len-1){
builder.append(",");
}
}
}
builder.append(")");
String jsFunc = builder.toString();
XLogUtil.d("jsFunc:"+jsFunc);
webView.post(() -> {
if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT){
//4.4版本以上,调用带返回值js方法
webView.evaluateJavascript(jsFunc, new ValueCallback<String>() {
@Override
public void onReceiveValue(String value) {
XLogUtil.d("jsFunc :"+jsFunc +",onReceiveValue:"+value);
if(callback != null){
callback.onReceiveValue(value);
}
}
});
}else {
webView.loadUrl("javascript:" + jsFunc);
}
});
}
复制代码
JS调用Android代码的方法有3种:一般用第一种
- 1.通过WebView的addJavascriptInterface()进行对象映射
- 2.通过 WebViewClient 的shouldOverrideUrlLoading ()方法回调拦截 url
- 3.通过 WebChromeClient 的onJsAlert()、onJsConfirm()、onJsPrompt()方法回调拦截JS对话框alert()、confirm()、prompt() 消息
注意: js调用android时的安全性(addJavascriptInterface):
public static void keepsafe(WebView webView,boolean debugable){
if (Build.VERSION.SDK_INT > 10 &&Build.VERSION.SDK_INT < 17) {
webView.removeJavascriptInterface("searchBoxJavaBridge_");
}
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
WebView.setWebContentsDebuggingEnabled(debugable);
}
}
复制代码
以上所述就是小编给大家介绍的《android webview总结》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
JavaScript DOM编程艺术
Jeremy Keith / 杨涛、王建桥、杨晓云 / 人民邮电出版社 / 2006年12月 / 39.00元
本书讲述了JavaScript和DOM的基础知识,但重点放在DOM编程技术背后的思路和原则:预留退路、循序渐进和以用户为中心等,这些概念对于任何前端Web开发工作都非常重要。本书将这些概念贯穿在书中的所有代码示例中,使你看到用来创建图片库页面的脚本、用来创建动画效果的脚本和用来丰富页面元素呈现效果的脚本,最后结合所讲述的内容创建了一个实际的网站。 本书适合Web设计师和开发人员阅读。一起来看看 《JavaScript DOM编程艺术》 这本书的介绍吧!