Android webview 与js交互


关于中 java代码与h5 中js交互的问题已经是老生常谈的事情了,之前在开发中也有遇到过,但是一直没总结

今天刚好碰到一个同事遇到了这个问题,在帮他解决的同时也在这里总结下常规步骤和注意事项

Webview 与js 交互

  1. 设置webview中允许执行js 代码,这句是基础(废话.

     web.getSettings().setJavaScriptEnabled(true); 
    
  2. 为webview 与js直接建立一个共享对象 (这里为了简洁直接使用了所在的Activity类对象,指定js调用的字段名(这里取名叫 app 可以修改,建议统一

     web.addJavascriptInterface(this, "app")  ;
    
  3. 创建与js交互的方法 ,这里这个方法直接写在Activity 中了, 在4.2及以上记得在方法上带上注解@JavascriptInterface,这是因为在js直接与java代码进行交互的话存在漏洞,比方你可以利用java的反射调用一些系统方法,总之没有限制是很危险的事情。

    注意: request_data js所调用的java端的所有方法会在子线程中执行,不要直接在方法中进行更新ui的操作

     @JavascriptInterface
     public void request_data(String year, String month, int dic){}
    
  4. js端调用java方法 window.app.request_data 这里的 app 即为第二步中为js申明的共享字段名 如果你修改了这个名字,一定要提醒的前端队友同步修改,前端也是你写的话,当我没说

     window.app.request_data(year,month,0);
    
  5. java调用js方法。 heartJson 为你要传递过去的值,因为java和js对象是不互通的,如果需要传递对象和数组之类的,请将对象和数组转json之后再使用下面的方法拼接然后调用,对象数组要转json,对象数组要转json,对象数组要转json 重要的事情说三遍

     web.loadUrl("javascript:chartHeartRate(" + heartJson + ")")
    

注意事项: web端直接将json作为参数传递:window.app.invokeMethod(json); 这样,安卓端获取的参数也是不可用的,打印出来是undefinded 网页中一定要这样处理一下,再作为参数传递:

var jsonStr = JSON.stringify(json);
window.app.invokeMethod(jsonStr);

这样,安卓端才能获取到json的字符串,创建出json的对象进行解析。