dart的继承和消息循环机制

我来为您详细介绍Dart语言中extension on的运用。首先让我查看一下完整的文件内容,以便更好地理解当前的扩展实现。

现在让我查看一下是否有其他相关的扩展使用示例,以便为您提供更全面的介绍。

基于您提供的代码,我来详细介绍一下Dart语言中extension on的运用。

Dart Extension 扩展方法详解

1. 基本语法

Dart中的extension允许您为现有的类添加新的功能,而无需修改原始类或创建子类。基本语法如下:

dart 复制代码
extension ExtensionName on Type {
  // 添加的方法、getter、setter等
}

2. 示例分析

示例1:为int类型添加扩展

dart 复制代码
extension IntFix on int {
  ///eg:200.px
  double get px {
    return ScreenHelper.getPx(toDouble());
  }
}

示例2:为double类型添加扩展

dart 复制代码
extension DoubleFix on double {
  ///eg:200.0.px
  double get px {
    return ScreenHelper.getPx(this);
  }
}

示例3:为String类型添加扩展

arduino 复制代码
extension StringExt on String{ 
    // 2. 扩展方法
    int add(int x, int y){ return x + y; } 
} 
void mian(){ 
    String str = 'hello'; 
    // 3. 使用扩展类方法 int result = str.add(3, 7); 
    debugPrint(result.toString()); 
}

3. Extension 的主要特性

3.1 添加方法

dart 复制代码
extension StringExtension on String {
  bool get isNullOrEmpty => isEmpty;
  
  String capitalize() {
    if (isEmpty) return this;
    return this[0].toUpperCase() + substring(1).toLowerCase();
  }
}

3.2 添加Getter/Setter

dart 复制代码
extension ListExtension<T> on List<T> {
  T? get firstOrNull => isEmpty ? null : first;
  
  T? get lastOrNull => isEmpty ? null : last;
}

3.3 操作符重载

dart 复制代码
extension DateTimeExtension on DateTime {
  DateTime operator +(Duration duration) => add(duration);
  DateTime operator -(Duration duration) => subtract(duration);
}

4. 使用场景

4.1 工具类扩展(如您的示例)

dart 复制代码
// 使用方式
double width = 200.px;  // 将200转换为适配后的像素值
double height = 300.5.px; // 将300.5转换为适配后的像素值

4.2 字符串处理

dart 复制代码
extension StringValidation on String {
  bool get isValidEmail => RegExp(r'^[\w-\.]+@([\w-]+\.)+[\w-]{2,4}$').hasMatch(this);
  bool get isValidPhone => RegExp(r'^1[3-9]\d{9}$').hasMatch(this);
}

4.3 集合操作

dart 复制代码
extension ListUtils<T> on List<T> {
  List<T> distinct() => toSet().toList();
  
  List<T> whereNotNull() => where((element) => element != null).toList();
}

5. 命名规则和导入

5.1 命名约定

  • 扩展名应该清晰表达其功能
  • 通常使用Extension后缀,如StringExtensionListExtension

5.2 导入方式

dart 复制代码
import 'extensions.dart' as ext;

// 使用
var result = ext.someExtensionMethod();

6. 限制和注意事项

6.1 不能访问私有成员

扩展只能访问目标类的公共接口,不能访问私有成员。

6.2 不能添加实例变量

扩展只能添加方法、getter、setter和操作符,不能添加实例变量。

6.3 冲突解决

如果多个扩展为同一类型定义了相同名称的成员,需要使用显式调用:

dart 复制代码
// 如果有冲突
MyExtension(obj).someMethod();

7. 实际应用示例

基于您的屏幕适配需求,扩展的使用非常优雅:

dart 复制代码
class MyWidget extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    ScreenHelper.init(context, baseWidth: 375); // 初始化适配
    
    return Container(
      width: 200.px,    // 自动适配
      height: 100.px,   // 自动适配
      child: Text('Hello World'),
    );
  }
}

8. 优势总结

  1. 代码简洁:避免了繁琐的静态方法调用
  2. 类型安全:编译器可以检查类型正确性
  3. 可读性强:代码更符合自然语言表达
  4. 易于维护:相关功能集中管理
  5. 无侵入性:不需要修改原始类

扩展为屏幕适配提供了非常优雅的解决方案,使得代码更加简洁和易读。

相关推荐
落霞的思绪1 小时前
配置React和React-dom为CDN引入
前端·react.js·前端框架
Hacker_Z&Q1 小时前
CSS 笔记2 (属性)
前端·css·笔记
Anastasiozzzz1 小时前
LeetCode Hot100 295. 数据流的中位数 MedianFinder
java·服务器·前端
Exquisite.2 小时前
Nginx
服务器·前端·nginx
打小就很皮...2 小时前
dnd-kit 实现表格拖拽排序
前端·react.js·表格拖拽·dnd-kit
Ulyanov2 小时前
从静态到沉浸:打造惊艳的Web技术发展历程3D时间轴
前端·javascript·html5·gui开发
打小就很皮...2 小时前
React 19 + Vite 6 + SWC 构建优化实践
前端·react.js·vite·swc
Highcharts.js2 小时前
使用Highcharts与React集成 官网文档使用说明
前端·react.js·前端框架·react·highcharts·官方文档
这是个栗子2 小时前
AI辅助编程(二) - 通译千问
前端·ai·通译千问
VT.馒头2 小时前
【力扣】2625. 扁平化嵌套数组
前端·javascript·算法·leetcode·职场和发展·typescript