美文网首页收藏
Dart编码:`extension` 这样用更高效

Dart编码:`extension` 这样用更高效

作者: 李小轰 | 来源:发表于2021-12-03 13:44 被阅读0次

前言

extension 可以在不更改类或创建子类的情况下,向类添加扩展功能的一种方式。灵活使用 extension 对基础类进行扩展,对开发效率有显著提升。

举个栗子🌰,对 int 类型扩展

小轰在开发项目中碰到需求:将单位为分的数值转换成单位为元的字符串

/// 通常的写法,封装转换方法

///封装方法:金额转字符串 保留两位小数
String convertPointToUnit(int num){
    return (num.toDouble() / 100).toStringAsFixed(2);
}

///使用
void main(){
    int num = 100;
    var result = convertPointToUnit(num);
    print(result);  //打印结果为 1.00
}

同样的功能,使用 extension 进行开发,会更加简洁,如下:

/// 使用 extension 对 int 类进行扩展,添加方法 moneyString
extension ExInt on int {
  /// 金额转字符串 保留两位小数
  /// 100 => 1.00
  String get moneyString => (this.toDouble() / 100).toStringAsFixed(2);
}

import ../ExInt.dart;
///使用
void main(){
    int num = 100;
    print(num.moneyString); 
}

扩展后,直接作为该类型的成员方法来被使用。extension 就像是基因赋值,直接将能力(方法)对宿主进行赠与。

各种场景的扩展演示

  • 对枚举进行扩展实现
enum FruitEnum { apple, banana }

extension ExFruitEnum on FruitEnum {
  String get name {
    switch (this) {
      case FruitEnum.apple:
        return "apple";
      case FruitEnum.banana:
        return "banana";
    }
  }
}

///字符串匹配枚举
FruitEnum generateFruit (String fruitType){
    if(fruitType == FruitEnum.apple.name){
        return FruitEnum.apple;
    } else if(fruitType == FruitEnum.banana.name){
        return FruitEnum.banana;
    }
}
  • 扩展作用于泛型:
//扩展list的方法
extension ExList<T> on List<T> {
  //扩展操作符
  List<T> operator -() => reversed.toList();
  //一个链表分割成两个
  List<List<T>> split(int at) => <List<T>>[sublist(0, at), sublist(at)];
}
  • 扩展在 Widget 控件中的应用
    我们会有类似的控件
Column(
    children: <Widget>[
        Container(
            paddint: const EdgeInsets.all(10)
            child: AWidget(),
        ),
        Container(
            paddint: const EdgeInsets.all(10)
            child: BWidget(),
        ),
        Container(
            paddint: const EdgeInsets.all(10)
            child: CWidget(),
        ),
    ]
)

代码中有很多的冗余对吧?我们用 extension 进行扩展一下:

extension ExWidget on Widget {
  Widget paddingAll(double padding) {
    return Container(
      paddint: const EdgeInsets.all(padding)
      child: this,
    );
  }
}

之后我们就可以改成:

Column(
    children: <Widget>[
        AWidget().paddingAll(10),
        BWidget().paddingAll(10),
        CWidget().paddingAll(10),
    ]
)

欢迎评论区分享更多有趣的用法~

相关文章

  • Dart编码:`extension` 这样用更高效

    前言 extension 可以在不更改类或创建子类的情况下,向类添加扩展功能的一种方式。灵活使用 extensio...

  • Map 排序 ーー Dart extension 扩展

    Map 排序 ーー Dart extension 扩展 前言 用 Flutter 中的扩展方法对 Map 进行升序...

  • Neumorphism 组件 ーー Dart extension

    Neumorphism 组件 ーー Dart extension 扩展 前言 创建 Neumorphism Flu...

  • Flutter扩展函数

    在Dart 2.7 版本中,新加入了一个重要的语法功能,叫做extension。Extension的主要功能给已经...

  • Dart 编码规范:正确处理 null

    前言 在 Dart 编码中,我们会经常遇到需要处理 null 的场合。Dart 2.12版本引入 null saf...

  • Dart extension之扩展方法

    今早无意间看到了 Dart 居然也支持 Api 的扩展,感觉就好像发现了新大陆,之前写的好多转换方法都可以换一个更...

  • Dart语法学习1

    前言 为什么学习Dart? Dart语法简洁高效,拥有数以千计的packages 生态系统 Dart 提供提前编...

  • iOS App Today Extension 初探

    最近在做手机屏幕直播,基于Replaykit,通过Brocast Upload Extension 进行编码和推流...

  • Flutter Dart 编码规范

    注释 要像句子一样格式化 除非是区分大小写的标识符,否则第一个单词要大写。以句号结尾(或“!”或“?”)。对于所有...

  • dart学习总结

    一、Dart 入口方法介绍 Dart打印 Dart注释 Dart变量 常量申明 变量命名规则 1.变量声明,用va...

网友评论

    本文标题:Dart编码:`extension` 这样用更高效

    本文链接:https://www.haomeiwen.com/subject/hcnpxrtx.html