码迷,mamicode.com
首页 > 移动开发 > 详细

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

时间:2014-06-16 19:20:36      阅读:261      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   tar   com   get   

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("调用失败!");
    }

基于PhoneGap3.4框架的iOS插件的实现,布布扣,bubuko.com

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

标签:style   blog   http   tar   com   get   

原文地址:http://blog.csdn.net/cwb1128/article/details/31149893

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!