【Flutter】抽象类的运用(abstract与implements的实践)

使用场景:功能支持两种接口模式,使用抽象类分别实现接口

1、定义抽象类及统一接口

复制代码
abstract class UploadStrategy {
  /// 抽象上传方法
  /// [file]:待上传文件
  /// [onSendProgress]:进度回调(已上传字节数,总字节数)
  Future<String> upload({
    required File file,
    Function(int, int)? onSendProgress
  });
}

2、通过创建策略工厂类(根据类型获取上传实例)

复制代码
class UploadStrategyFactory {
  static UploadStrategy getStrategy(
    UploadApiType type) {
    switch (type) {
      case UploadApiType.aLiYun:
        return AliYunUploader();
      case UploadApiType.sam:
        return SamUploader();
    }
  }
}

3、通过implements分别实现自定义上传接口

复制代码
/// 阿里云OSS上传实现
class AliYunUploader implements UploadStrategy {
  @override
  Future<String> upload({
    required File file,
    Function(int, int)? onSendProgress
  }) async {
    // 复用原阿里云上传逻辑
    return await AliyunOss.upload(
      file: file,
      onSendProgress: onSendProgress,
    );
  }
}

//上传实现
class SamUploader implements UploadStrategy {
  @override
  Future<String> upload({
    required File file,
    Function(int, int)? onSendProgress
  }) async {
    return await FileUploadService()
        .uploadCommon(file);
  }
}

4、使用示例:

复制代码
 final uploader = UploadStrategyFactory.getStrategy(uploadType);
    try {
      final urls = await Future.wait(
        files.map(
          (file) => uploader.upload(
            file: file,
            onSendProgress: onSendProgress,
          ),
        ),
      );

      UIToast.showSuccess('上传成功');
      successCallback(urls);
    } catch (e) {
      UIToast.showError('上传失败: ${e.toString()}');
    } finally {
      UIToast.dismissHud();
    }

总结:虽然可以通过参数方式实现不同类型接口的功能,但通过抽象类可以减少逻辑,并更加简便的使用上传方法,后期若有增加类型,也更容易维护。

相关推荐
Lanren的编程日记32 分钟前
Flutter 鸿蒙应用错误处理优化实战:完善全局异常捕获,全方位提升应用稳定性
flutter·华为·harmonyos
Lanren的编程日记42 分钟前
Flutter鸿蒙应用开发:网络请求优化实战,全方位提升请求稳定性与性能
网络·flutter·harmonyos
IntMainJhy1 小时前
【futter for open harmony】Flutter 鸿蒙聊天应用实战:shared_preferences 本地键值存储适配指南[特殊字符]
flutter·华为·harmonyos
IntMainJhy1 小时前
【Flutter for OpenHarmony 】第三方库鸿蒙电商实战|首页模块完整实现[特殊字符]
flutter·华为·harmonyos
梦想不只是梦与想2 小时前
flutter 与原生通信的底层原理(二)
flutter
Lanren的编程日记2 小时前
Flutter 鸿蒙应用离线模式实战:无网络也能流畅使用
网络·flutter·harmonyos
IntMainJhy3 小时前
【Flutter for OpenHarmony 】第三方库 聊天应用:Provider 状态管理实战指南
flutter·华为·harmonyos
IntMainJhy3 小时前
【futter for open harmony】Flutter 聊天应用实战:Material Design 3 全局 UI 规范落地指南✨
flutter·华为·harmonyos
IntMainJhy3 小时前
【flutter for open harmony】Flutter 聊天应用实战:go_router 路由管理完全实现指南
flutter·华为·harmonyos
liulian09163 小时前
【Flutter For OpenHarmony第三方库】Flutter 页面导航的鸿蒙化适配实战
flutter·华为·学习方法·harmonyos