在开发cordova(phonegap、ionic)应用时,很多情况下需要用到一些h5无法实现的原生功能,这时候就需要用到插件。
在cordova的plugin库中已经有很多已经编写好的插件,可以登录官网cordova官网搜索,然后使用
cordova plugin add cordova-plugin-xxx
在项目中添加插件使用。但是有些时候我们需要的功能网上并没有现成插件、或者是我们自己所实现的原生功能,这时候我们就需要自己编写插件。整个过程可以参照现有的Apache组织编写的插件,如cordova-plugin-device等。
这里编写了一个cordova-plugin-mjtest插件,使用原生方法在控制台打印出前台传入的name的值。
这里所有操作在platform下的ios/android下完成
在h5应用中,界面所调用的语言首先是js,这里是定义一些在应用中需要用到js方法。
cordova.define("cordova-plugin-mjtest.mjtest", function(require, exports, module) {
var exec = require('cordova/exec');
var mjtest = {
test : function (args,successCallback,errorCallback){
cordova.exec(successCallback,errorCallback,"Mjtest","test",args);
}
};
module.exports = mjtest;
});
建立文件夹取名cordova-plugin-mjtest放在www的plugins下(名字随意取)
在原有插件配置下添加:
{
"file": "plugins/cordova-plugin-mjtest/www/mjtest.js",
"id": "cordova-plugin-mjtest.mjtest",
"pluginId": "cordova-plugin-mjtest",
"clobbers": [
"window.plugins.mjtest"
]
}
iOS下:
<feature name="Mjtest">
<param name="ios-package" value="Mjtest" />
feature>
android下:
<feature name="Mjtest">
<param name="android-package" value="org.apache.cordova.mjtest.Mjtest" />
feature>
这里首先要会基本的android或者oc语法,swift暂时未尝试不知道是否有兼容问题。
具体的详细方法在cordova官网中有,如需要可以去查看,下面是我的代码:
android:
package org.apache.cordova.mjtest;
import org.apache.cordova.CallbackContext;
import org.apache.cordova.CordovaInterface;
import org.apache.cordova.CordovaPlugin;
import org.apache.cordova.CordovaWebView;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import android.app.Activity;
import android.content.Context;
import android.content.SharedPreferences;
import android.util.Log;
/**
* Created by maxbalance on 12/21/15.
*/
public class Mjtest extends CordovaPlugin{
/**
* Sets the context of the Command. This can then be used to do things like
* get file paths associated with the Activity.
*
* @param cordova The context of the main Activity.
* @param webView The CordovaWebView Cordova is running in.
*/
public void initialize(CordovaInterface cordova, CordovaWebView webView) {
super.initialize(cordova, webView);
}
/**
* Executes the request and returns PluginResult.
*
* @param action The action to execute.
* @param args JSONArry of arguments for the plugin.
* @param callbackContext The callback id used when calling back into JavaScript.
* @return True if the action was valid, false if not.
*/
public boolean execute(String action, JSONArray args, CallbackContext callbackContext) throws JSONException {
//test
if ("test".equals(action)) {
final JSONObject options = args.getJSONObject(0);
System.out.println(options.getString("name"));
callbackContext.success(options.getString("name"));
}
return true;
}
}
其中主要的方法为initialize与execute,第一个是定义,基本不许要修改,第二个方法是控制逻辑的。callbackContext是回调方法,是通信的关键,上面是成功回调,如果失败回调的话调用callbackContext.success
即可。
iOS:
Mjtest.h
#import
#import
@interface Mjtest : CDVPlugin
- (void)test:(CDVInvokedUrlCommand*)command;
@end
Mjtest.m
#import "Mjtest.h"
#import
@implementation Mjtest
#pragma mark test
- (void)test:(CDVInvokedUrlCommand*)command {
NSDictionary* options = [command.arguments objectAtIndex:0];
//test
NSString *name = [options objectForKey:@"name"];
NSLog(@"%@",name);
CDVPluginResult * pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_OK messageAsString:name];
[self.commandDelegate sendPluginResult:pluginResult callbackId:command.callbackId];
}
@end
同样这里ios是成功回调,失败回调为:
CDVPluginResult* pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_ERROR messageAsString:errorRes];
[self.commandDelegate sendPluginResult:pluginResult callbackId:command.callbackId];
errorRes为错误的NSString
在配置config.xml中我们定义了一个参数为
"clobbers": ["window.plugins.mjtest"]
这个一般以cordova开头,尽量不要起单个单词。
而window.plugins.mjtest这个就是js中调用的函数,而mjtest.js中定义的方法(test)就由这个方法函数调用。
if(window.cordova){
window.plugins.mjtest.test([{'name':'mj'}],function(data){consoloe.log(data)});
}
这个在浏览器中无法运行,使用前请判断cordova
使用xcode/android studio运行,就可以在控制台查看效果了,或者可以在回调中获取回调数据。
因为过程比较长,所以写的比较省略,主要以代码为主。而且这种插件只能自己使用,无法做成统一插件,下一篇会介绍如何把插件做成和cordova-plugin-device一样可供下载安装的插件(同时也会少些一些代码)。
代码地址:https://github.com/MaxBalance/cordova-plugin-mjtest