Flutter-OH 核心概念:Package(包)与 Plugin(插件)的区别详解

欢迎大家 加入跨平台开发者社区

核心区别详解

首先要明确:Flutter-OH的Plugin是一种特殊的Package,但两者的核心差异在于是否涉及OpenHarmony(鸿蒙)原生平台代码。下面用通俗易懂的方式拆解:

1. Flutter-OH Package(纯Dart包)
  • 核心定义:仅由 Dart 代码 构成,不包含任何OpenHarmony(鸿蒙)的原生代码(如ArkTS)。
  • 运行层面:完全运行在Flutter-OH的Dart VM中,不与鸿蒙原生系统直接交互。
  • 适用场景:实现纯Flutter-OH层的复用功能,比如:
    • UI组件(如自定义按钮、列表、弹窗)
    • 工具类(如日期格式化、字符串处理、数据解析)
    • 状态管理(如provider、bloc的Flutter-OH适配版)
    • 网络请求(如dio的Flutter-OH适配版)
  • 开发难度:低,只需掌握Dart语言,无需了解鸿蒙原生开发。
  • 典型例子dio(Flutter-OH适配版,网络请求)、flutter_screenutil(Flutter-OH适配版,屏幕适配)、provider(Flutter-OH适配版,状态管理)。
2. Flutter-OH Plugin(鸿蒙原生交互插件)
  • 核心定义:由 Dart 代码 + OpenHarmony原生代码(主要是ArkTS) 共同构成,是连接Flutter-OH和鸿蒙原生系统的桥梁。
  • 运行层面:Dart层代码作为“接口”,通过Flutter-OH的通信机制调用鸿蒙原生代码实现功能,最终将结果返回给Flutter-OH。
  • 适用场景:需要调用鸿蒙原生系统能力或硬件功能的场景,比如:
    • 访问鸿蒙设备硬件(相机、蓝牙、传感器、鸿蒙分布式能力)
    • 调用鸿蒙系统功能(相册、定位、推送、鸿蒙服务卡片)
    • 集成鸿蒙原生SDK(支付、地图、鸿蒙生态的第三方服务)
  • 开发难度:高,除了Dart,还需要掌握OpenHarmony原生开发技能(主要是ArkTS语言、鸿蒙API)。
  • 典型例子camera_ohos(Flutter-OH相机调用插件)、shared_preferences_ohos(Flutter-OH本地存储插件)、location_ohos(Flutter-OH定位插件)。
关键对比表
维度 Flutter-OH Package Flutter-OH Plugin
核心代码构成 仅Dart代码 Dart代码 + 鸿蒙原生代码(ArkTS)
与鸿蒙系统交互 必须通过鸿蒙原生代码交互
开发所需技能 仅Dart Dart + OpenHarmony原生开发(ArkTS)
适用场景 纯Flutter-OH层功能复用 调用鸿蒙系统/硬件/分布式能力
发布方式 发布到pub.dev 发布到pub.dev

补充说明

  • 从广义上讲,Flutter-OH的Plugin属于Package的范畴(pub.dev市场上所有可依赖的Flutter-OH模块都叫Package),但开发者口中的“Flutter-OH Package”通常特指纯Dart包,“Flutter-OH Plugin”特指带鸿蒙原生代码的包
  • 开发Flutter-OH Plugin时,依然基于Flutter的统一通信机制(MethodChannel、EventChannel等),适配鸿蒙平台后,实现Dart代码和鸿蒙ArkTS代码的双向通信。
  • 部分Flutter原生Package(纯Dart)可直接适配Flutter-OH使用,无需修改;但Flutter原生Plugin(Android/iOS)需重新开发鸿蒙原生层代码,才能适配为Flutter-OH Plugin。

总结

  1. 核心差异:Flutter-OH Package是纯Dart代码的复用模块,不涉及鸿蒙原生;Flutter-OH Plugin包含鸿蒙原生(ArkTS)代码,用于Flutter-OH调用鸿蒙系统/硬件/分布式能力。
  2. 开发选择:仅需Dart就能实现的功能用Package,需要访问鸿蒙原生API(如硬件、分布式能力、系统功能)用Plugin。
  3. 技能要求:开发Flutter-OH Package只需Dart,开发Flutter-OH Plugin需掌握Dart + OpenHarmony原生开发(ArkTS)技能。
Logo

开源鸿蒙跨平台开发社区汇聚开发者与厂商,共建“一次开发,多端部署”的开源生态,致力于降低跨端开发门槛,推动万物智联创新。

更多推荐