phoneGap插件开发-多参数和返回值

2017-02-27  本文已影响0人  prostory

标签(空格分隔): Android phoneGap


在编写PhoneGap插件时,要传递多个参数,需要将参数保存在一个参数数组中,然后PhoneGap会自动将参数数组保存在JSONArray对象中;如果要获取返回值,需要编写回调方法将返回值通过参数传递到回调方法中,示例代码(myplugin.js)如下:

/**
 * 构造方法
 */

function MyPlugin() {
};

/**
 * 字符串相加
 *
 * @param str1, str2
 */
MyPlugin.prototype.addStr = function(successCallback, failureCallback, str1, str2) {
    PhoneGap.exec(successCallback, failureCallback, "MyPlugin", "addStr", [str1, str2]);
};

/**
 * 加载MyPlugin对象
 */
PhoneGap.addConstructor(function() {
    PhoneGap.addPlugin("myPlugin", new MyPlugin());
});

然后在Java代码中调用JSONArray的getString(int index)方法获取JSONArray中的参数,通过index指定参数的索引就可以取得多个参数了;在Java代码中,返回值是保存在PluginResult对象中的,PluginResult保存了状态和返回值。如果状态为OK,则回调successCallback方法,并将返回值传递到该方法中;如果状态为JSON_EXCEPTION,则回调failureCallback方法,并将错误信息传递到该方法中。示例代码(MyPlugin.java)如下:

package com.litsoft.phonegap;

import org.apache.cordova.api.PluginResult;
import org.json.JSONArray;
import org.json.JSONException;
import com.phonegap.api.Plugin;
public class MyPlugin extends Plugin {

    @Override
    public PluginResult execute(String action, JSONArray args, String callbackId) {
        PluginResult.Status status = PluginResult.Status.OK;
        String result = "";
        try {
            if(action.equals("addStr")){
                result = addStr(args.getString(0), args.getString(1));
            }else{
                status = PluginResult.Status.INVALID_ACTION;
            }
        
            return new PluginResult(status, result);
        } catch (JSONException e) {
            return new PluginResult(PluginResult.Status.JSON_EXCEPTION);
        }
    }

    /**
     * 两个字符串相加
     * 
     * @param str1
     * @param str2
     * @return
     */
    
    private String addStr(String str1, String str2){
        return str1 + str2;
    }
}

最后在html中调用插件中的方法,通过调用addStr方法就可以将两个输入框的值传递到后台Java代码中运行,后台Java将返回值存储在PluginResult对象中,通过编写回调方法successCallback就可以获取返回值了。示例代码(index.html)如下:

<!DOCTYPE HTML>
<html>
<head>
<title>PhoneGap</title>
<script type="text/javascript" charset="utf-8" src=\'#\'" /span>
</script>
<script type="text/javascript" charset="utf-8" src=\'#\'" /span>
</script>
<script type="text/javascript" charset="UTF-8">
    function add(){
        var str1 = document.getElementById("str1Id").value;
        var str2 = document.getElementById("str2Id").value;
        window.plugins.myPlugin.addStr(successCallback, failureCallback, str1, str2);
    }

    //成功时回调的方法
    function successCallback(data){
        document.getElementById("resultId").value = data;
    }

    //失败时返回的方法   
    function failureCallback(data){
        alert("error:"+ data);
    }
</script>
</head>

<body>
<input type="text" id="str1Id"/>
<br />
<input type="text" id="str2Id" />
<br />
<input type="text" id="resultId" />
<input type="button" value="add" onclick="add();" />
</body>
</html>
上一篇 下一篇

猜你喜欢

热点阅读