如何为ionic webapp开发自定义插件

 我来答
huanglenzhi
2015-12-12 · 知道合伙人数码行家
huanglenzhi
知道合伙人数码行家
采纳数:117538 获赞数:517199
长期从事计算机组装,维护,网络组建及管理。对计算机硬件、操作系统安装、典型网络设备具有详细认知。

向TA提问 私信TA
展开全部
  安装cordova插件管理工具,plugman
  在终端中输入:
  npm install -g plugman
  安装命令与安装结果如下:

  2
  新建一个插件myEcho,用弹出框来显示我们的内容。
  plugman create --name <pluginName> --plugin_id <pluginID> --plugin_version <version> [--path <directory>] [--variable NAME=VALUE]
  把其中的<pluginName>替换为 myEcho;
  <pluginID> 替换为 com.lulee007.myEcho
  <version> 替换为 0.0.1
  [--path <directory>] [--variable NAME=VALUE] 这两个是可选参数,这里不写了。这样会在当前目录下(desktop)创建一个新的目录myEcho
  在终端中输入:
  plugman create --name myEcho --plugin_id com.lulee007.myEcho --plugin_version 0.0.1

  执行命令后会在当前目录下生成一个文件夹,我这里的目录是在桌面下的myEcho.

  3
  向myEcho项目中添加一个android平台
  plugman platform add --platform_name <platform>
  把<platform>替换为 android
  接着在终端中继续输入:
  cd myEcho
  然后输入:
  plugman platform add --platform_name android
  这时候查看我们的myEcho目录下的 src会新增一个目录android里面会有一个java文件:myEcho.java

  END
  插件项目修改配置
  项目结构组成:
  src 对应不同的平台,www 放我们的 javascript 文件,plugin.xml 是插件的配置文件。

  2
  先来看看配置文件:plugin.xml
  解释一下关键的几个元素:
  id: 插件的标识,即一开始我们新建插件输入的 ID,com.lulee007.myEcho
  name:插件的名称,新建插件时输入的名称,myEcho
  description:描述信息
  js-module:对应我们的 javascript 文件,src 属性指向 www/myEcho.js
  platform:支持的平台,这里仅有一个 android,这是刚才我们通过“ plugman platform add --platform_name android ”添加进来的。
  其中android下的config-file:
  这里是android插件的配置信息,当安装到应用时,会添加到目标平台android下的 res/xml/config.xml 文件中,并将 src/android/myEcho.java,复制到 android 的 package 包中。

  3
  看下javascript文件:myEcho.js
  文件内容很简单,第一句是引入cordova下的exec库
  第二句是我们插件的执行插件方法,
  exec(success, error, "myEcho", "coolMethod", [arg0]);
  success:调用成功时的回调函数,
  error:调用出错时的回调函数,
  "myEcho":插件名称,
  "coolMethod":执行插件里的方法,
  [arg0]:可选参数,执行方法的参数数组。
  这里我们把“exports.coolMethod”改为“window.plugins.myEcho”
  并在“exports.coolMethod”上面添加一行:
  window.plugins = window.plugins || {};
  同样把“coolMethod”也改为“echo”。
  最终修改后的js文件内容如图:

  4
  接着修改myEcho.java文件
  可以看到myEcho继承自CordovaPlugin,并重载了execute方法。
  在execute方法里有个判断,action.equals("coolMethod"),这表示如果执行的是我们的方法那就继续执行内部的逻辑并返回true,如果不是则直接返回false结束。
  这里我们修改下方法:“coolMethod”为“echo”,并把方法coolMethod名称修改为echo。
  最终修改后的java文件内容如下:

  END
  安装测试插件
  这里用事先准备好的ionic项目myFirstApp来测试我们的插件。
  这里不再赘述ionic项目的创建,具体可以参考我的另一篇经验。
  直接在百度经验里搜索:如何用ionicframework进行混合移动应用开发
  第一篇就是。

  打开终端,在终端中输入:
  cd myFirstApp
  切换到myFirstApp目录下
  输入:
  cordova plugin add ../myEcho
  显示已经安装myEcho插件到ios和android平台下

  打开myFirstApp目录,可以看到在plugins目录下多了一个com.lulee007.myEcho目录。

  打开myFirstApp目录下的www/js/controllers.js
  添加如下代码到最后“PlaylistCtrl”位置:
  window.plugins.myEcho("echo my text",
  function(data){
  alert(data);
  },
  function(error){
  alert(error);
  });

  重新build然后run进行调试:
  在终端里输入:
  ionic build android
  然后输入:
  ionic run --device android
  执行命令后结果如下图:

  这时android设备上已经运行了我们的应用:
  随便点击list的一个项,会弹出一个对话框,内容是“echo my text”

  最后如果我们在测试中需要对插件进行更新,这时候只需要执行命令:
  cordova plugin remove com.lulee007.myEcho
  这里的“com.lulee007.myEcho”就是我们最开始新建插件的时候的插件ID。
  重新安装还是这个命令:
  cordova plugin add path/to/your/plugin/dir
  把“path/to/your/plugin/dir”替换为自己的插件的目录就好了。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式