TAT.iAzrael 让Java跟Javascript更加亲密
In JavaScript on 2013年02月20日 by view: 8,369
2

在移动App开发中,为了快速迭代,通常都会使用Native+Web的模式开发。具体来说就是使用Java提供接口,使用WebView控件嵌套Web页面来实现UI和交互。

在Android中,Java可以很方便的提供接口给WebView中的Js进行调用,只要以下一行代码就能搞定:

这样,JavascriptInterface的所有声明为public的方法,都能被mWebView中的Js通过以下方式调用:

而Java需要调用Js时,则是通过WebView实例的loadUrl方法调用:

这其实跟你在浏览器的地址栏敲下“javascript:alert(1)”的原理是一样的。

一切看起来都是那么的美好,只是……

当Java需要传递大量字符串给Js时,URL就力不从心了。另外,从URL执行的Js,在页面没加载完成时,是有可能导致页面出现undefined错误(因为要执行的那个方法可能还没有声明呢),会引发各种奇形怪状的错误。

 

那要怎么办呢?

再回看上面Js调用Java接口的地方,可以发现,Js是可以直接调用Java方法并取得Java给的返回值的(必须是可序列化的数据)。那么,为何不试试把Java需要执行的Js方法,保存起来,让Js来读取、执行、并把结果写回?

步骤如下:

  1. Java把Js调用(命令)和回调缓存,如保存到ArrayList;
  2. Js定时轮询Java提供的getCommandList接口;
  3. Js读取到要执行命令,执行它,并把结果通过setResult写回给Java;
  4. Java把对应命令的回调取出并执行。

如此即完成了Java调用Js的流程。

为了方便使用,简单的封装了下,名为AndroidJavascriptBridge,可移步到Github查看源码和示例(MainActivity.java和test.js )。

使用方法

Android端调用, 加入com.imatlas.jsb 和 com.imatlas.util包, 按如下步骤调用

Javascript端的调用, 须先引入web/js/jsb.js, 之后按如下方式调用

IOS的话就要反过来了,要改成由Objective-C来轮询Js,来实现Js对Native的调用。

嗯,等改天有时间了,就把IOS也封装进来,用起来就简单多了。

 

原创文章转载请注明:

转载自AlloyTeam:http://www.alloyteam.com/2013/02/rang-java-gen-javascript-geng-jia-qin-mi/

  1. 星期八 2014 年 5 月 7 日

    java调用js对于参数太长的情况实现太绕了,完全可以让java去调用js时给定一个func_id,然后js再去调用java拿到参数

  2. HCM 2013 年 8 月 19 日

    倒是用过 开发 安卓 移动办公的时候 一同的 JAVA+JS 它们交互的空间是 WebView Native+Web 模式开发的
    当时 做游戏的使用 用的 OC 里面的 WebView +JS 有一定的好处 但是 还是需要一个客户端 这是不好的地方 !!

发表评论