在Android上实现Java和Js交互
- - ITeye博客 其实webview加载资源的速度并不慢,但是如果资源多了,当然就很慢. 图片、 css 、 js 、 html 这些资源每个大概需要 10-200ms ,一般都是 30ms 就 ok 了. 不过webview是必须等到全部资源都完成加载,才会进行渲染的,所以加载的速度很重要. 从Google上我们了解到,webview 加载页面的顺序是:先加载 html ,然后从里面解析出 css 、 js 文件和页面上的图片资源进行加载.
谈起js在服务端的应用,大部分人的第一反应都是node.js。node.js作为一套服务器端的 JavaScript 运行环境,有自己的独到之处,但不是所有的地方都需要使用它。
例如在已有的服务端代码上增加一个业务,而这个业务使用的却是js编写。如果用node.js处理的话,会很麻烦。而且另一方面对于很多服务端程序员来说,觉得js的对象模型很奇怪,不太喜欢用js处理问题。
对于上面这种情况,有一种简单的处理方法: javax.script API
javax.script加入了对部分脚本语言的支持,它的原意是为了针对关于业务在客户端和服务端中,逻辑相同而语言不同导致实现不同的问题。但是这种处理方法由于前后端的分工和一些缺陷,很少在实际应用中用到。
javax.script
实现起来很简单。ScriptEngineManager maneger = new ScriptEngineManager(); ScriptEngine engine = maneger.getEngineByName("JavaScript");
Reader scriptReader = new InputStreamReader( JsInServer.class.getResourceAsStream("js文件"));
engine.eval(scriptReader);
Object result = invocable.invokeFunction("js方法", js方法参数1, js方法参数2...);
java
import java.io.IOException; import java.io.InputStreamReader; import java.io.Reader; import javax.script.Invocable; import javax.script.ScriptEngine; import javax.script.ScriptEngineManager; import javax.script.ScriptException; public class JsInServer { public static void main(String[] arg) throws IOException { ScriptEngineManager maneger = new ScriptEngineManager(); ScriptEngine engine = maneger.getEngineByName("JavaScript"); Reader scriptReader = new InputStreamReader( JsInServer.class.getResourceAsStream("TestAdd.js")); if (engine != null) { try { // JS引擎解析文件 engine.eval(scriptReader); if (engine instanceof Invocable) { Invocable invocable = (Invocable) engine; // JS引擎调用方法 Object result = invocable.invokeFunction("add", 1, 2); System.out.println("The result is: " + result); } } catch (ScriptException e) { e.printStackTrace(); } catch (NoSuchMethodException e) { e.printStackTrace(); } finally { scriptReader.close(); } } else { System.out.println("ScriptEngine create error!"); } } }
js:
function add(a,b){ println("The first parameter is: " + a); println("The second parameter is: " + b); return a+b; } println("js perform success");
执行结果:
js perform success The first parameter is: 1 The second parameter is: 2 The result is: 3.0