JavaScript学习之Android与JS交互

来源:互联网 发布:tomcat 多域名绑定 编辑:程序博客网 时间:2024/06/05 00:24
先学JS,再学jQuery,不学Angular:
1、Android调用JS函数更新网页数据
   JSONObject ytbDetail = new JSONObject();
   法一:
   webview.loadUrl("javascript:jsRequest('"+ytbDetail.toString()+"')");
   function jsRequest(appStr){
     val str = new Function("return" + appStr)();
(此时str为json对象,可以直接str.key这样取值)
   }
   法二:
   webview.loadUrl("javascript:jsRequest("+ytbDetail+")");
   function jsRequest(str){
    (此时str为json对象,可以直接str.key这样取值)
   }
   
2、JS调用Android对象的方法进行跳转:
    法一:<a class="f1" onclick="clickDetail('+val.borrowid+')" href="ytObjDetail.html">查看详情</a>
    法二:'<a class="fl" href= "javascript:clickDetail('+ '\''+ val.borrowid + '\'' + ',' + '\'' + val.title + '\'' + ')">查看详情</a>'
字符串形式的参数要用单引号,否则会提示字符串未定义
function clickDetail(id,title){
  window.JSInterface.getDetail(id,title);
}
Android:
webview.getSettings().setJavaScriptEnabled(true);
webview.addJavascriptInterface(new MyHandler,"JSInterface");
class MyHandler{
@JavascriptInterface
 public void getDetail(String id,String title){
    Intent intent = new Intent(ExcellentPlanActivity.this,YoutbDetaiActivity.class);
            intent.putExtra("ytbData",ytbData);
            intent.putExtra("title",title);
            startActivity(intent);
 }
}
原创粉丝点击