Dart 3 Record 语法快速入门指南

简介: 学习如何使用Dart中的record类型,这种匿名、不可变的聚合类型将帮助您更高效地管理数据。

Dart 3 Record 语法快速入门指南

视频

https://youtu.be/06WmVjp06D0

https://www.bilibili.com/video/BV1Kt42157Xv/

前言

原文 https://ducafecat.com/blog/dart-syntax-record-usage-guide

学习如何使用Dart中的record类型,这种匿名、不可变的聚合类型将帮助您更高效地管理数据。

了解如何定义和使用,以及常见使用场景。

参考

https://dart.dev/language/records

在线编辑器

https://dartpad.dev/

定义 Record 类型

快速定义

  var name = 'Bob';
  var age = 20;
  var isVip = true;

  var userInfo = (name, age, isVip);

  print('name: ${userInfo.$1}');
  print('age: ${userInfo.$2}');
  print('isVip: ${userInfo.$3}');

需要通过 userInfo.$1 的方式访问

命名定义

  var name = 'Bob';
  var age = 20;
  var isVip = true;

  var userInfo = (name: name, age: age, isVip: isVip);

  print('name: ${userInfo.name}');
  print('age: ${userInfo.age}');
  print('isVip: ${userInfo.isVip}');

通过 name: name 方式指定名称,方便调用 userInfo.name

指定类型

  (String, int, bool) userInfo = (name, age, isVip);

  print('name: ${userInfo.$1}');
  print('age: ${userInfo.$2}');
  print('isVip: ${userInfo.$3}');

指定命名类型

  ({
   
   String name, int age, bool isVip}) userInfo =
      (name: name, age: age, isVip: isVip);

  print('name: ${userInfo.name}');
  print('age: ${userInfo.age}');
  print('isVip: ${userInfo.isVip}');

定义赋值分开写

// 定义
({
   
   String name, int age, bool isVip}) userInfo;

// 赋值
userInfo = (name: name, age: age, isVip: isVip);

解构方式读取

// 定义,赋值
({
   
   String name, int age, bool isVip}) userInfo =
      (name: name, age: age, isVip: isVip);

// 解构读取
final (:name, :age, :isVip) = userInfo(json);
print("$name, $age, $isVip");

使用场景

直接返回经纬度

({
   
   double latitude, double longitude}) getLocation() {
   
   
  // 返回经纬度
  return (latitude: 37.7749, longitude: -122.4194);
}

void main(List<String> arguments) {
   
   
  var location = getLocation();
  print(
      "Location latitude: ${location.latitude}, longitude: ${location.longitude}");
}

函数方式处理 json 数据

// 函数
(String name, int age) userInfo(Map<String, dynamic> json) {
   
   
  return (json['name'] as String, json['age'] as int);
}

// 数据
final json = <String, dynamic>{
   
   
  'name': 'Dash',
  'age': 10,
  'color': 'blue',
};

// 执行处理
var (name, age) = userInfo(json);

/* Equivalent to:
  var info = userInfo(json);
  var name = info.$1;
  var age  = info.$2;
*/

合并数据集合

如返回博客文章,我们需要一次返回文章、评论、关联推荐.

以前原来我们需要定义一个返回类 Class。

class ArticleDetail {
   
   
  final String article;
  final List<String> comments;
  final List<String> related;

  ArticleDetail(this.article, this.comments, this.related);
}
Future<ArticleDetail> GetArticle(String uri) async {
   
   
  String article;
  List<String> comments;
  List<String> related;

  ...

  return ArticleDetail(article, comments, related);
}

现在直接返回 Record 对象

Future<({
   
   String article, List comments, List related})> getArticle(String uri) async {
   
   
  String article;
  List<String> comments;
  List<String> related;

  ...

  return  (article: article, comments: comments, related: related);
}
void main(List<String> arguments) {
   
   
  final (:article, :comments, :related) = getArticle(123);
}

小结

今天讲了下 Record 的匿名、命名定义、赋值使用,以及使用场景,优点我总结如下:

  • 减少了繁琐的类型定义
  • 快速集合多个数据
  • 配合解构使用 : 冒号语法
  • 适合处理 map 数据转模型 class

感谢阅读本文

如果有什么建议,请在评论中让我知道。我很乐意改进。


© 猫哥
ducafecat.com

end

相关文章
|
存储 设计模式 Dart
Flutter笔记:getX库中的GetView中间件
Flutter笔记:getX库中的GetView中间件
592 0
|
4月前
|
机器学习/深度学习 人工智能 自然语言处理
面向认知智能的AI推理体系:理论基础与工程实践
本文深入探讨了AI推理从“感知智能”迈向“认知智能”的理论框架与技术突破。文章分析了符号推理、神经推理及混合推理的优劣势,指出了多跳推理、因果推理和可解释性等挑战。同时,结合大语言模型、ReAct架构和知识增强推理等前沿技术,展示了AI推理在代码实现中的应用。未来,认知图谱、推理驱动的智能体、边缘推理优化及人机协同将成为重要方向,推动AI向通用人工智能(AGI)迈进。
465 60
面向认知智能的AI推理体系:理论基础与工程实践
|
9月前
|
Dart 前端开发 容器
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
249 18
【07】flutter完成主页-完成底部菜单栏并且做自定义组件-完整短视频仿抖音上下滑动页面-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
SQL Oracle 关系型数据库
sql开发
【5月更文挑战第20天】sql开发
734 1
|
12月前
|
编解码 弹性计算 运维
AWS无服务器直播解决方案
AWS无服务器直播解决方案
|
12月前
|
安全 Java 关系型数据库
探索后端技术:构建高效、安全的应用服务
在当今数字化浪潮中,后端技术作为软件架构的核心支柱,承载着处理数据逻辑、保障应用性能与安全等关键任务。本文旨在深入浅出地探讨后端开发的重要概念、主流技术栈以及未来发展趋势,为开发者提供一份指南,以助力构建既高效又安全的应用程序。
|
测试技术 API Android开发
Android 性能测试初探 (一)
Android 性能测试,跟pc性能测试一样分为客户端及服务器,但在客户端上的性能测试分为 2 类: 一类为 rom 版本的性能测试;一类为应用的性能测试。
208 3
【python绘图库turtle实战】使用python绘图库turtle绘制:太阳花、彩虹线与小黄人【含完整源码】
【python绘图库turtle实战】使用python绘图库turtle绘制:太阳花、彩虹线与小黄人【含完整源码】
|
缓存 JavaScript
vue 页面缓存 keep-alive(含配置清除页面缓存 exclude,局部缓存,动态缓存,路由控制缓存 $route.meta.keepAlive)
vue 页面缓存 keep-alive(含配置清除页面缓存 exclude,局部缓存,动态缓存,路由控制缓存 $route.meta.keepAlive)
1288 0
|
移动开发 缓存 Dart
Pad大屏&Flutter多引擎适配之路
# 背景 在电商场景中iPad的大屏拥有比普通手机相比更大的屏幕,对于购物体验而言,如能充分利用好iPad的大屏体验,无疑提高用户购买体验,但一直以来在混合栈应用特别是Flutter混合栈中,在iPad大屏适配和Flutter多引擎适配都是个老大难问题。本文会介绍闲鱼在这iPad适配中的各个疑难点。 # 分屏模式 华为,oppo等厂商折叠屏的方案。界面会在展开和折叠时展示不同的视图样式。op
Pad大屏&Flutter多引擎适配之路