基于PhoneGap3.4框架的iOS插件的实现

Phonegap 提供了iOS 设备的基础特性接口来供HTML页面调用,但是这些基础接口不能满足我们的一些特殊需求,所以有时候我们需要开发插件来扩展其功能。基于PhoneGap3.4框架的iOS插件开发,主要分以下几个步骤:

1)搭建PhoneGap3.4的iOS开发环境,搭建步骤参考此文章

2)编写.h头文件,示例代码如下:

#import <Cordova/CDVPlugin.h>

@interface CDVLogin : CDVPlugin
    - (void)login:(CDVInvokedUrlCommand*)command;
@end

3)编写.m源代码文件,示例代码如下:

#import "CDVLogin.h"

@implementation CDVLogin
   - (void)login:(CDVInvokedUrlCommand*)command{
    NSString *echo = @"NIL";
     //插件返回值
    CDVPluginResult *pluginResult = nil;
    //获取传递过来的参数
    NSString *param = [command.arguments objectAtIndex:0];
   Boolean  loginStatus = [self  loginSystem:param];
    if(loginStatus){
        echo = @"YES";
 //成功时插件的返回值
        pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_OK messageAsString:echo];
    }else{
        echo = @"NO";
 //失败时插件的返回值
        pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_ERROR messageAsString:echo];
    }
    [self.commandDelegate sendPluginResult:pluginResult callbackId:command.callbackId];
   
}
-(Boolean) loginSystem:(NSString *)para
{
    return YES;
}
@end

4)在config.xml 里注册插件,如下:

<feature name="Login">
        <param name="ios-package" value="CDVLogin"/>
    </feature>

5)js调用,如下:

var CustomPlugin = {
    callNativeMethod: function (success, fail, param) {
        var exec = cordova.require("cordova/exec");
        return exec(success, fail,"Login","login",[param]);
    }
};

function callNativePlugin( param ) {
    CustomPlugin.callNativeMethod( nativePluginResultHandler, nativePluginErrorHandler, param );
}
function nativePluginResultHandler (result) {
    // alert("SUCCESS: \r\n" + result);
}
function nativePluginErrorHandler (error) {
    if(error == "NO"){
        alert("调用失败!");
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值