Cordova入门系列(四)自定义Cordova插件--showToast

前三篇Cordova入门系列,简单讲解了Cordova,以及如何调用Cordova插件,今天我们讲解一下如何自己做一个插件。

  自定义插件,就是自己写一些安卓java代码,然后和js代码以及配置文件,封装成一个cordova插件。通过js代码,调用安卓java代码,从而实现调用原生的东西。只不过这些调用原生的行为是我们为了我们自己特定的需求写的,而不是Cordova官方的。。。

  自定义插件的结构:  

  |---pluginName                        
    |---src
      |---android
        |---XXX.java

      |---ios
    |---www
      |---xxx.js
    |---plugin.xml

 

  我们今天做一个名字叫showToast的插件,用户点击的时候,会调用安卓原生的Toast去显示。目录结构如下:

  

  

  先看showToast.js

复制代码
 
cordova.define("myPlugins.showToast", function(require, exports, module) {
    var exec = require('cordova/exec');
    var myFunc = function(){};
    // arg1:成功回调
    // arg2:失败回调
    // arg3:将要调用类配置的标识,要在feature中配置的
    // arg4:调用的原生方法名
    // arg5:参数,json格式
    myFunc.prototype.show=function(success, fail) {
        exec(success, fail, "ShowToast", "show", []);
    };
    
    var showtoast = new myFunc();
    module.exports = showtoast;
});
 
复制代码

 

  再看ShowToast.java

复制代码
 
package myPlugin;

import org.apache.cordova.CallbackContext;
import org.apache.cordova.CordovaPlugin;
import org.json.JSONArray;
import org.json.JSONException;
import android.app.Activity;
import android.widget.Toast;

public class ShowToast extends CordovaPlugin {

    @Override
    public boolean execute(String action, JSONArray args, CallbackContext callbackContext) throws JSONException {
        Activity activity = cordova.getActivity();

        if("show".equals(action)) {
            Toast.makeText(activity, "this is my plugin showToast", Toast.LENGTH_SHORT).show();
        }

        callbackContext.success("toast success");
        return true;
    }
}
 
复制代码

 

  plugin.xml

复制代码
 
<?xml version="1.0" encoding="UTF-8"?>
<plugin xmlns="http://apache.org/cordova/ns/plugins/1.0"
    xmlns:android="http://schemas.android.com/apk/res/android"
    id="myPlugins.showToast"
    version="0.0.1">
    <name>showToast</name>
    <description>this is the plugin witch use js to call Toast</description>

    <js-module src="www/showToast.js">
        <clobbers target="myPlugins.showToast"/>
    </js-module>

    <platform name="android">
        <source-file src="src/android/ShowToast.java" target-dir="src/myPlugin"/>

        <config-file target="res/xml/config.xml" parent="/*">
            <feature name="ShowToast">
                <param name="android-package" value="myPlugin.ShowToast"/>
            </feature>
        </config-file>

        <config-file target="AndroidManifest.xml" parent="/*">
            <uses-permission android:name="android.permission.READ_PHONE_STATE" />
        </config-file>
    </platform>

</plugin>
 
复制代码

 

  安装这个插件到项目中,cordova plugin add “插件的路径”

  然后调用:

复制代码
 
myPlugins.showToast.show(
    function(msg){
        console.log(msg);
    },
    function(msg){
        console.log(msg);
    }
);
 
复制代码
posted @   brave-sailor  阅读(588)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
历史上的今天:
2017-04-25 android 获取蓝牙已连接设备
2017-04-25 你的理解对吗?详解“右侧超车”正确含义
2014-04-25 Android中Style和Theme的使用
2014-04-25 高仿优酷Android客户端图片左右滑动(自动切换)
点击右上角即可分享
微信分享提示