uniApp实战三:自定义插件的实现

文章目录

1.最终效果预览

2.页面布局

定义一个按钮触发点击事件

复制代码
		<view @click="testClick">
			<text >调试</text>
		</view>

点击方法如下

复制代码
testClick(){
				const dcRichAlert = uni.requireNativePlugin('yichen-test');
				dcRichAlert.testAsyncFunc({
					title: "提示信息",
					name: '张三'
				}, result => {
					console.log('result: ', JSON.stringify(result));
				});
				
			}

3.插件开发

在AS中我们引入uni官方提供的示例UniPlugin-Hello-AS右键新建Module并定义类继承UniModule如下,添加一个testAsyncFunc方法,即上一步方法中调用的方法

复制代码
public class MyTest extends UniModule {

    String TAG = "MyTest";
    public static int REQUEST_CODE = 1000;

    //run ui thread
    @UniJSMethod(uiThread = true)
    public void testAsyncFunc(JSONObject options, UniJSCallback callback) {
        if(callback != null) {
            JSONObject data = new JSONObject();
            data.put("code", "success");
            data.put("age", 123);
            data.put("title", options.getString("title"));
            data.put("name", options.getString("name"));
            Log.e(TAG, "testAsyncFunc--"+data.toString());
            callback.invoke(data);
        }
    }

    //run JS thread
    @UniJSMethod (uiThread = false)
    public JSONObject testSyncFunc(){
        JSONObject data = new JSONObject();
        data.put("code", "success");
        return data;
    }

    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        if(requestCode == REQUEST_CODE && data.hasExtra("respond")) {
            Log.e("TestModule", "原生页面返回----"+data.getStringExtra("respond"));
        } else {
            super.onActivityResult(requestCode, resultCode, data);
        }
    }


}

在app目录中的assets目录下找到dcloud_uniplugins.json,把我们刚才新建的插件定义上

复制代码
{
      "plugins": [
        {
          "type": "module",
          "name": "yichen-test",
          "class": "com.example.uniplugin_mytest.MyTest"
        }
      ]
    },

type对应的值固定为module,name中的值自己定义,当在uni中使用插件会用到,class中的值为我们插件写的类所在的包名+类名

4.编译uni页面

如下图所示生成本地打包资源

打包资源生成后将\unpackage\resources目录下的文件拷贝到AS工程\UniPlugin-Hello-AS\app\src\main\assets\apps目录下并将assets\data目录下的dcloud_control.xml中appid对应的值改为uniApp项目的包名

5.平台申请离线key

https://dev.dcloud.net.cn/pages/app/list 平台中找到我们新建的应用,点击应用名称然后选择各平台信息,填写应用的包名、SHA1值、SHA256,这几个值根据自己打包的证书文件查看即可,填写完会生成离线key,将key值拷贝,找到AndroidManifest.xml文件并找到如下代码,替换其中的xxxx即可

复制代码
 <meta-data
            android:name="dcloud_appkey"
            android:value="xxxxx" />

6.根据证书文件查看SHA1及SHA256值

将安装的jdk的bin添加到系统变量中以便我们能访问keytool工具,打开cmd命令窗口输入如下命令查看证书文件的值

复制代码
keytool -list -v -keystore D:\xxx.keystore

输入密码回车即可查到sha1及sha256的值,xxx.keystore如果没有可以用as新建一个,点几下就行。

7.将模块编译为aar包并生成插件

在AS工程右侧找到自己的插件模块 然后点击如下图所示生成aar包

在HbuilderX中新建如下图所示目录集成

注意package.json和android文件夹同级,这里官网应该写错了放到android文件夹里面去了,这样会导致本地找不到这个插件建好后可以将下列内容拷贝到package.json文件中,或者在插件跟目录下执行npm init一样会生成但是也是需要修改里面信息的

复制代码
{
	"name": "uniPluginsTest",
	"id": "yichen-test",
	"version": "1.0.0",
	"description": "uniPluginsTest",
	"_dp_type":"nativeplugin",
	"_dp_nativeplugin":{
		"android": {
			"plugins": [
				{
					"type": "module",
					"name": "yichen-test",
					"class": "com.example.uniplugin_mytest.MyTest"
				}
			],
			"integrateType": "aar"
		}
		
	}
}

_dp_type对应的值是固定的 plugins中的值直接和第三步插件开发dcloud_uniplugins.json中的值一样就行,integrateType得值固定为aar

8.勾选本地插件并打自定义基座包

在HbuilderX中找到manifest.json然后如下图勾选插件,然后再选云打包,打自定义基座包即可。

相关推荐
盛夏绽放7 小时前
关于 uni-app 与原生微信小程序中的生命周期 —— 一次“生命旅程”的解读
微信小程序·小程序·uni-app
知识分享小能手7 小时前
uni-app 入门学习教程,从入门到精通,uni-app 基础知识详解 (2)
前端·javascript·windows·学习·微信小程序·小程序·uni-app
2501_916008899 小时前
iOS 发布全流程详解,从开发到上架的流程与跨平台使用 开心上架 发布实战
android·macos·ios·小程序·uni-app·cocoa·iphone
风清云淡_A11 小时前
【uniapp】uni.uploadFile上传数据多出一个304的get请求处理方法
uni-app
shykevin11 小时前
uni-app x商城,商品列表组件封装以及使用
windows·uni-app
cesske11 小时前
uniapp 编译支付宝小程序canvas 合成图片实例,支付宝小程序 canvas 渲染图片 可以换成自己的图片即可
小程序·uni-app·apache
Q_Q51100828521 小时前
python+uniapp基于微信小程序的旅游信息系统
spring boot·python·微信小程序·django·flask·uni-app·node.js
2501_916007471 天前
iOS 混淆工具链实战,多工具组合完成 IPA 混淆与加固(iOS混淆|IPA加固|无源码混淆|App 防反编译)
android·ios·小程序·https·uni-app·iphone·webview
游戏开发爱好者81 天前
FTP 抓包分析实战,命令、被动主动模式要点、FTPS 与 SFTP 区别及真机取证流程
运维·服务器·网络·ios·小程序·uni-app·iphone
2501_915909061 天前
iOS 26 文件管理实战,多工具组合下的 App 数据访问与系统日志调试方案
android·ios·小程序·https·uni-app·iphone·webview