NCr
NCr
  • 发布:2025-04-15 11:11
  • 更新:2025-04-16 10:51
  • 阅读:584

根据dcloud官方UTS插件开发文档创建uts插件,打包报错

分类:uts

http://doc.dcloud.net.cn/uni-app-x/plugin/uts-plugin.html#%E8%8E%B7%E5%8F%96%E7%94%B5%E9%87%8F%E6%8F%92%E4%BB%B6%E7%A4%BA%E4%BE%8B

https://app.liuyingyong.cn/build/errorLog/ac8ea330-19a3-11f0-941d-41ad7db9cd2b

index.uts文件


/**  
 * 引用 Android 系统库,示例如下:  
 * import { Context } from "android.content.Context";  
 * [可选实现,按需引入]  
 */  

/* 引入 interface.uts 文件中定义的变量 */  
import { MyApiOptions, MyApiResult, MyApi, MyApiSync } from '../interface.uts';  

/* 引入 unierror.uts 文件中定义的变量 */  
import { MyApiFailImpl } from '../unierror';  
import Context from "android.content.Context";  
import BatteryManager from "android.os.BatteryManager";  

export function getBatteryCapacity(): string {  
    // 获取android系统 application上下文  
    const context = UTSAndroid.getAppContext();  
    if (context != null) {  
        const manager = context.getSystemService(  
            Context.BATTERY_SERVICE  
        ) as BatteryManager;  
        const currentLevel: number = manager.getIntProperty(  
            BatteryManager.BATTERY_PROPERTY_CAPACITY  
        );  
        return '' + currentLevel + '%';  
    }  
    return "0%";  
}  
/**  
 * 引入三方库  
 * [可选实现,按需引入]  
 *  
 * 在 Android 平台引入三方库有以下两种方式:  
 * 1、[推荐] 通过 仓储 方式引入,将 三方库的依赖信息 配置到 config.json 文件下的 dependencies 字段下。详细配置方式[详见](https://uniapp.dcloud.net.cn/plugin/uts-plugin.html#dependencies)  
 * 2、直接引入,将 三方库的aar或jar文件 放到libs目录下。更多信息[详见](https://uniapp.dcloud.net.cn/plugin/uts-plugin.html#android%E5%B9%B3%E5%8F%B0%E5%8E%9F%E7%94%9F%E9%85%8D%E7%BD%AE)  
 *  
 * 在通过上述任意方式依赖三方库后,使用时需要在文件中 import,如下示例:  
 * import { LottieAnimationView } from 'com.airbnb.lottie'  
 */  

/**  
 * UTSAndroid 为平台内置对象,不需要 import 可直接调用其API,[详见](https://uniapp.dcloud.net.cn/uts/utsandroid.html#utsandroid)  
 */  

/**  
 * 异步方法  
 *  
 * uni-app项目中(vue/nvue)调用示例:  
 * 1、引入方法声明 import { myApi } from "@/uni_modules/uts-api"  
 * 2、方法调用  
 * myApi({  
 *   paramA: false,  
 *   complete: (res) => {  
 *      console.log(res)  
 *   }  
 * });  
 * uni-app x项目(uvue)中调用示例:  
 * 1、引入方法及参数声明 import { myApi, MyApiOptions } from "@/uni_modules/uts-api";  
 * 2、方法调用  
 * let options = {  
 *   paramA: false,  
 *   complete: (res : any) => {  
 *     console.log(res)  
 *   }  
 * } as MyApiOptions;  
 * myApi(options);  
 *  
 */  
export const myApi : MyApi = function (options : MyApiOptions) {  
  if (options.paramA == true) {  
    // 返回数据  
    const res : MyApiResult = {  
      fieldA: 85,  
      fieldB: true,  
      fieldC: 'some message'  
    };  
    options.success?.(res);  
    options.complete?.(res);  
  } else {  
    // 返回错误  
    const err = new MyApiFailImpl(9010001);  
    options.fail?.(err)  
    options.complete?.(err)  
  }  
}  

/**  
 * 同步方法  
 *  
 * uni-app项目中(vue/nvue)调用示例:  
 * 1、引入方法声明 import { myApiSync } from "@/uni_modules/uts-api"  
 * 2、方法调用 myApiSync(true)  
 *  
 * uni-app x项目(uvue)中调用示例:  
 * 1、引入方法及参数声明 import { myApiSync } from "@/uni_modules/uts-api";  
 * 2、方法调用 myApiSync(true)  
 */  
export const myApiSync : MyApiSync = function (paramA : boolean) : MyApiResult {  
  // 返回数据,根据插件功能获取实际的返回值  
  const res : MyApiResult = {  
    fieldA: 85,  
    fieldB: paramA,  
    fieldC: 'some message'  
  };  
  return res;  
}  

只要在vue页面调用,打包就报错
https://app.liuyingyong.cn/build/errorLog/94885620-19bc-11f0-8aaa-a72b5981e08b

2025-04-15 11:11 负责人:无 分享
已邀请:
DCloud_Android_DQQ

DCloud_Android_DQQ

看这个报错和UTS插件应该没有关系。你试着去掉UTS插件重新提交打包。

  • NCr (作者)

    我尝试一下

    2025-04-15 11:42

  • NCr (作者)

    移除uts插件可以打包成功

    2025-04-15 12:21

  • NCr (作者)

    保留插件和移除插件都可以正常打包,只要在vue页面调用打包就会报错

    2025-04-15 14:07

DCloud_Android_DQQ

DCloud_Android_DQQ

提交一下可以复现问题的最简示例

要回复问题请先登录注册