android cordova 最新版本开发,Cordova插件开发(iOS/Android)--看这篇就够了

其他Cordova相关文章链接

1.创建一个测试工程

//创建cordova工程

cordova create cordovaTest com.szcomtop.cordovaTest cordovaTest

//进入platforms目录

//添加iOS 和 Android 平台代码

cd platforms

cordova platform add ios

cordova platform add android

2.创建插件

//安装插件工具

npm install -g plugman

/**创建一个 弹出alert的插件

name:插件名称

plugin_id:插件id

plugin_version:插件版本

**/

plugman create --name mytoast --plugin_id com.example.mytoast --plugin_version 0.0.1

执行完之后会看见一个mytoast文件夹在根目录下的plugins目录里面。把文件夹名称改成com.example.mytoast

2.1 生成package.json文件

//进入到插件目录

cd plugins/mytoast

//执行创建package.json文件

plugman createpackagejson ./

按照默认的选项提示创建即可

2.2 创建iOS/Android原生代码

iOS代码 — AlertPlugin.h 文件

#import

#import

NS_ASSUME_NONNULL_BEGIN

@interface AlertPlugin : CDVPlugin

//接收cordova消息方法

- (void)coolMethod:(CDVInvokedUrlCommand*)command;

@end

NS_ASSUME_NONNULL_END

iOS代码 — AlertPlugin.m 文件

#import "AlertPlugin.h"

@implementation AlertPlugin

- (void)coolMethod:(CDVInvokedUrlCommand*)command{

// NSLog(@"className:%@ - callbackId:%@ - args:%@ - methodName:%@",

// command.className,command.callbackId,command.arguments,command.methodName);

if (command.arguments.count > 0) {

UIAlertController *alertCtr = [UIAlertController alertControllerWithTitle:@"显示的标题" message:command.arguments[0] preferredStyle:UIAlertControllerStyleAlert];

UIAlertAction *okAction = [UIAlertAction actionWithTitle:@"OK" style:(UIAlertActionStyle)UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {

CDVPluginResult *result = [CDVPluginResult resultWithStatus:CDVCommandStatus_OK messageAsString:@"OC回传给js的参数"];

[self.commandDelegate sendPluginResult:result callbackId:command.callbackId];

}];

[alertCtr addAction:okAction];

[[UIApplication sharedApplication].windows.firstObject.rootViewController presentViewController:alertCtr animated:YES completion:^{

}];

}else{

CDVPluginResult *result = [CDVPluginResult resultWithStatus:CDVCommandStatus_ERROR messageAsString:@"没有参数"];

[self.commandDelegate sendPluginResult:result callbackId:command.callbackId];

}

}

@end

Android代码 — mytoast.java

package com.example.mytoast;

import org.apache.cordova.CordovaPlugin;

import org.apache.cordova.CallbackContext;

import org.json.JSONArray;

import org.json.JSONException;

import org.json.JSONObject;

//导包

import android.widget.Toast;

public class mytoast extends CordovaPlugin {

@Override

public boolean execute(String action, JSONArray args, CallbackContext callbackContext) throws JSONException {

if (action.equals("coolMethod")) {

String message = args.getString(0);

this.coolMethod(message, callbackContext);

return true;

}

return false;

}

private void coolMethod(String message, CallbackContext callbackContext) {

if (message != null && message.length() > 0) {

callbackContext.success(message);

//吐司内容

Toast.makeText(cordova.getContext(),message, Toast.LENGTH_LONG) .show();

} else {

callbackContext.error("Expected one non-empty string argument. ");

}

}

}

2.3 修改plugin.xml,添加iOS和Android平台相关字段

mytoast

2.4 插件最终的目录结构

com.example.mytoast

|-- package.json

|-- plugin.xml

|-- src

|-- ios

|-- AlertPlugin.h

|-- AlertPlugin.m

|-- android

|-- mytoast.java

|-- www

|-- mytoast.js

按照上面的目录结构,把原生文件放到对应的位置。

3. 测试插件

3.1 执行cordova命令添加插件

//add 后面参数为 我们新创建的插件文件夹

cordova plugin add ./plugins/com.example.mytoast

3.2 编写测试index.html

Hello World

Apache Cordova

3.3 执行效果

Demo插件附件

官网参考地址

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值