Js调用Java方法并互相传参的简单实例


Posted in Javascript onAugust 11, 2016

Js通过PhoneGap调用Java方法并互相传参的。

一、JAVA代码

写一个类,该类继承自Plugin并重写execute方法。

import org.json.JSONArray;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.ActivityNotFoundException;
import android.content.DialogInterface;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import com.phonegap.api.PhonegapActivity;
import com.phonegap.api.Plugin;
import com.phonegap.api.PluginResult;

public class PluginTest extends Plugin {

 public static String ACTION = "hello";

  public PluginTest() {
  }

  /**
   * Executes the request and returns PluginResult.
   *
   * @param action     The action to execute.
   * @param args       JSONArray of arguments for the plugin.
   * @param callbackId  The callback id used when calling back into JavaScript.
   * @return         A PluginResult object with a status and message.
   */
  @Override
  public PluginResult execute(String action, JSONArray args, String callbackId) {
    try {
      JSONObject jsonObj = new JSONObject();//可以返回给JS的JSON数据
      if (action.equals("hello")) {
        String str1= args.getString(0); //获取第一个参数
        String str2= args.getString(1); //获取第二个参数
        jsonObj.put("str1", str1+"1"); //把参数放到JSONObject对象中
        jsonObj.put("str2", str2+"2");  //把参数放到JSONObject对象中
      }
      PluginResult r = new PluginResult(PluginResult.Status.OK,jsonObj);
      return r;
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
}

三、Javascript文件中注册插件

新建一个.js文件,并把该文件和phonegap文件放在同一目录。(新建一个simplePlugin.js文件)

var SimplePlugin = function() {};

//str1和str2是传到JAVA的参数
SimplePlugin.prototype.hello = function(successCallback, failureCallback, str1, str2) {
  // exec ?鹊??捣?e是: Success Callback, Failure Callback, Registered Plugin name:就是在XML文件配置的那个所对应的name,
  // 'hello'是传入Java文件的execute方法中的参数String action 
  // name (? HTML ?鬟M?淼???
  return PhoneGap.exec(successCallback, failureCallback, 'PluginTest', 'hello', [str1,str2]);
};

// 这里是 PhoneGap Plugin 的??裕?lugin 的名??有 Native Class 的名??e打?了,就是我???????入的那些
PhoneGap.addConstructor(function() {
  // Register the javascript plugin with PhoneGap
  PhoneGap.addPlugin('simpleplugin', new SimplePlugin());  //simpleplugin是插件名称, new SimplePlugin()实例化的是本Javascript的类名 

});

四、在HTML文件中调用方法

在html文件中引入phonegap和插件的js文件,调用方法

<!DOCTYPE html>
<html>
  <head>
  <meta charset="utf-8">
  <title>JAVA传参</title>
  <script src="phonegap.js"></script> <!--phonegap包-->
  <script src="js/jquery.js"></script>
  <script src="simplePlugin.js"></script><!--自定义的插件文件-->
  <script>  
  $(document).ready(function(e) {
    $("#btn_test").click(function(){
      window.plugins.simplePlugin.hello( 
        function(result) {
          alert("返回的第一个参数:"+result.str1+"返回的第二个参数"+result.str2);
        }, 
        function(error) {
        },
        "第一个参数",
        "第二个参数"
      );  
    });
  });
  </script>
  </head>
<body>
<button type="button" id="btn_test">Click Me!</button>
</body>
</html>

以上这篇Js调用Java方法并互相传参的简单实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
表单元素事件 (Form Element Events)
Jul 17 Javascript
Javascript 面向对象 继承
May 13 Javascript
深入探究使JavaScript动画流畅的一些方法
Jun 30 Javascript
javascript实现状态栏中文字动态显示的方法
Oct 20 Javascript
基于jquery实现最简单的选项卡切换效果
May 08 Javascript
详解vue-router 2.0 常用基础知识点之router.push()
May 10 Javascript
[js高手之路]设计模式系列课程-发布者,订阅者重构购物车的实例
Aug 29 Javascript
iview table render集成switch开关的实例
Mar 14 Javascript
element-ui组件table实现自定义筛选功能的示例代码
Mar 15 Javascript
详解vue使用$http服务端收不到参数
Apr 19 Javascript
vue安装遇到的5个报错及解决方法
Jun 12 Javascript
如何在VUE中使用vue-awesome-swiper
Jan 04 Vue.js
JS中的hasOwnProperty()、propertyIsEnumerable()和isPrototypeOf()
Aug 11 #Javascript
基于js对象,操作属性、方法详解
Aug 11 #Javascript
JS中的hasOwnProperty()和isPrototypeOf()属性实例详解
Aug 11 #Javascript
Node.js中防止错误导致的进程阻塞的方法
Aug 11 #Javascript
浅谈js中对象的使用
Aug 11 #Javascript
js倒计时简单实现代码
Aug 11 #Javascript
原生态js,鼠标按下后,经过了那些单元格的简单实例
Aug 11 #Javascript
You might like
一个选择最快的服务器转向代码
2009/04/27 Javascript
学习ExtJS Panel常用方法
2009/10/07 Javascript
Js 刷新框架页的代码
2010/04/13 Javascript
jQuery select操作控制方法小结
2010/05/26 Javascript
javascript实现促销倒计时+fixed固定在底部
2013/09/18 Javascript
javascript实用小函数使用介绍
2013/11/11 Javascript
javascript 获取函数形参个数
2014/07/31 Javascript
javascript引用赋值(地址传值)用法实例
2015/01/13 Javascript
EasyUI中实现form表单提交的示例分享
2015/03/01 Javascript
DeviceOne 让你一见钟情的App快速开发平台
2016/02/17 Javascript
基于Bootstrap实现tab标签切换效果
2020/04/15 Javascript
JS获取IE版本号与HTML设置IE文档模式的方法
2016/10/09 Javascript
简单理解js的冒泡排序
2016/12/19 Javascript
AngularJS 限定$scope的范围实例详解
2017/06/23 Javascript
Node.js实现文件上传的示例
2017/06/28 Javascript
angularjs实现过滤并替换关键字小功能
2017/09/19 Javascript
JS实现的对象去重功能示例
2019/06/04 Javascript
如何在Angular8.0下使用ngx-translate进行国际化配置
2019/07/24 Javascript
使用layui的router来进行传参的实现方法
2019/09/06 Javascript
在vue中使用echars实现上浮与下钻效果
2019/11/08 Javascript
javascript实现前端分页功能
2020/11/26 Javascript
详解python时间模块中的datetime模块
2016/01/13 Python
Python采用Django制作简易的知乎日报API
2016/08/03 Python
tensorflow学习笔记之简单的神经网络训练和测试
2018/04/15 Python
Pandas之Dropna滤除缺失数据的实现方法
2019/06/25 Python
python使用递归的方式建立二叉树
2019/07/03 Python
详解Django模版中加载静态文件配置方法
2019/07/21 Python
浅谈pytorch、cuda、python的版本对齐问题
2020/01/15 Python
python如何查看安装了的模块
2020/06/23 Python
python开发入门——set的使用
2020/09/03 Python
利用纯css3实现的文字亮光特效的代码演示
2014/11/27 HTML / CSS
大学生护理专业自荐信
2013/10/03 职场文书
《两个铁球同时着地》教学反思
2014/02/13 职场文书
苏州园林导游词
2015/02/03 职场文书
通知的写法
2015/04/23 职场文书
Docker与K8s关系介绍不会Docker也可以使用K8s
2022/06/25 Servers