欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Js調(diào)用Java方法并互相傳參的簡(jiǎn)單實(shí)例

 更新時(shí)間:2016年08月11日 10:22:13   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇Js調(diào)用Java方法并互相傳參的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

Js通過(guò)PhoneGap調(diào)用Java方法并互相傳參的。

一、JAVA代碼

寫一個(gè)類,該類繼承自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數(shù)據(jù)
      if (action.equals("hello")) {
        String str1= args.getString(0); //獲取第一個(gè)參數(shù)
        String str2= args.getString(1); //獲取第二個(gè)參數(shù)
        jsonObj.put("str1", str1+"1"); //把參數(shù)放到JSONObject對(duì)象中
        jsonObj.put("str2", str2+"2");  //把參數(shù)放到JSONObject對(duì)象中
      }
      PluginResult r = new PluginResult(PluginResult.Status.OK,jsonObj);
      return r;
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
}

三、Javascript文件中注冊(cè)插件

新建一個(gè).js文件,并把該文件和phonegap文件放在同一目錄。(新建一個(gè)simplePlugin.js文件)

var SimplePlugin = function() {};

//str1和str2是傳到JAVA的參數(shù)
SimplePlugin.prototype.hello = function(successCallback, failureCallback, str1, str2) {
  // exec 內(nèi)的參數(shù)分別是: Success Callback, Failure Callback, Registered Plugin name:就是在XML文件配置的那個(gè)所對(duì)應(yīng)的name,
  // 'hello'是傳入Java文件的execute方法中的參數(shù)String action 
  // name (從 HTML 傳進(jìn)來(lái)的參數(shù))
  return PhoneGap.exec(successCallback, failureCallback, 'PluginTest', 'hello', [str1,str2]);
};

// 這里是 PhoneGap Plugin 的註冊(cè),Plugin 的名稱還有 Native Class 的名稱別打錯(cuò)了,就是我們剛剛輸入的那些
PhoneGap.addConstructor(function() {
  // Register the javascript plugin with PhoneGap
  PhoneGap.addPlugin('simpleplugin', new SimplePlugin());  //simpleplugin是插件名稱, new SimplePlugin()實(shí)例化的是本Javascript的類名 

});

四、在HTML文件中調(diào)用方法

在html文件中引入phonegap和插件的js文件,調(diào)用方法

<!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("返回的第一個(gè)參數(shù):"+result.str1+"返回的第二個(gè)參數(shù)"+result.str2);
        }, 
        function(error) {
        },
        "第一個(gè)參數(shù)",
        "第二個(gè)參數(shù)"
      );  
    });
  });
  </script>
  </head>
<body>
<button type="button" id="btn_test">Click Me!</button>
</body>
</html>

以上這篇Js調(diào)用Java方法并互相傳參的簡(jiǎn)單實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論