Dart 2.3 | 让集合操作更加 fancy

栏目: IOS · Android · 发布时间: 5年前

内容简介:Flutter 作为 Dart 语言的一个重要框架,在过去的一年中取得了惊人的成长。这意味着将有非常多的开发者在使用 Dart 语言便携大型深层嵌套表达式的 UI。为了使 Dart 能够更好的编写声明式具有高可读性的 UI,最新发布的 Dart 2.3 版本为集合操作带来了更强的新特性!这篇文章将从以下主要几个方面带大家详细地讨论这些变化。相信各位在使用 Flutter 进行开发的时候经常会遇到这样的场景,当我们使用 Multiple child 组件时,会想要在 children 中添加一个集合,就像下面

Flutter 作为 Dart 语言的一个重要框架,在过去的一年中取得了惊人的成长。这意味着将有非常多的开发者在使用 Dart 语言便携大型深层嵌套表达式的 UI。为了使 Dart 能够更好的编写声明式具有高可读性的 UI,最新发布的 Dart 2.3 版本为集合操作带来了更强的新特性!这篇文章将从以下主要几个方面带大家详细地讨论这些变化。

  • Spread 语法
  • Collection if
  • Collection for

Whats New

Spread

相信各位在使用 Flutter 进行开发的时候经常会遇到这样的场景,当我们使用 Multiple child 组件时,会想要在 children 中添加一个集合,就像下面这样。

Dart 2.3 | 让集合操作更加 fancy
class App extends StatelessWidget {
  final List<String> data = ['name', 'theme', 'about us'];

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(),
      drawer: Drawer(
        child: ListView(
            children: [
          DrawerHeader(
              child: CircleAvatar(
            foregroundColor: Colors.blue,
          )),
        ]..addAll(data
                .map((text) => ListTile(
                      title: Text(text),
                    ))
                .toList())),
      ),
    );
  }
}
复制代码

在上面这段代码中,我们想向 children 里添加一个 List\<Widget> 我们只能通过 addAll 进行处理。看起来有点难受对吧,这样的做法大大降低了我们代码的可读性。但有了 Dart 2.3 的 Spread 语法,你将可以直接通过 ...List\<Widget> 在集合中添加另一个集合!

class App extends StatelessWidget {
  final List<String> data = ['name','theme','about us'];

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(),
      drawer: Drawer(
        child: ListView(children: <Widget>[
          DrawerHeader(child: CircleAvatar(foregroundColor: Colors.blue,)),
        ...data.map((text)=>ListTile(title: Text(text),)).toList(),
        ],),
      ),
    );
  }
}
复制代码

Awsome!这样的代码明显更有声明式的味道!并且你也可以很轻松的改变集合中元素的顺序。

Collection if

Dart 2.3 还支持在集合中使用 if 语句。

ListView(
    children: <Widget>[
        ...data.map((text) => ListTile(title: Text(text))).toList(),
        if (isGuest) Container(height: 200, color: Colors.amber)
      ],
    ),
复制代码

这样我们可以更加方便的在一个集合中判断是否需要显示这个小部件。并且这个操作可以和 Spread 结合使用。

ListView(
    children: <Widget>[
        if (isGuest)...data.map((text) => ListTile(title: Text(text))).toList(),
        Container(height: 200, color: Colors.amber)
      ],
    ),
复制代码

Collection for

不仅是 if 操作,现在你还能够在集合中使用 for 来处理每一个元素。

ListView(
    children: <Widget>[
        for(var text in data) ListTile(title: Text('action: $text'),),
        if (isGuest) for(var text in data) ListTile(title: Text('action: $text'),),
      ],
    ),
复制代码

如你所见,以上三个功能都可以自由组合。并且它们在 mapset literals 中同样适用。有关更改的完整详细信息,请参阅这个 官方提案

注意: const 集合当前不支持这些功能。在将来的版本中,Dart 团队打算放宽这个限制,并允许 ifconst 集合中传播和收集。

如何使用 Dart 2.3

目前 Flutter 1.5.5-pre.19 • channel master 可以使用 Dart 2.3,你可以通过依次执行下面的操作来更新到这个版本。

flutter channel master
flutter doctor
flutter upgrade

完成上述操作之后,你可以运行 flutter --version 来查看自己升级之后的版本,就像这样。

192:~ litavadaski$ flutter --version
Flutter 1.5.5-pre.19 • channel master • https://github.com/flutter/flutter.git
Framework • revision ac7f875778 (8 hours ago) • 2019-04-22 21:41:18 -0400
Engine • revision 0523870e0b
Tools • Dart 2.3.0 (build 2.3.0-dev.0.1 cf4444b803)
复制代码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

让大象飞

让大象飞

[美] 史蒂文·霍夫曼 / 周海云、陈耿宣 / 中信出版社 / 2017-3 / 69.00

这是一本为中国创业者量身定做的创业指南,将帮助创业者理解创新的基本方法、模式和硅谷的创业理念。作者霍夫曼频繁地穿梭于中美两地,与不同的创业者、投资人、政府负责人进行对话,积累了大量的来自中国创业者的第一手经验。在这本书里,从创业团队的人员配备到创业融资的成败再到团队的高效管理,从创业者的心理素质到创业者的独到眼光再到企业赖以生存的根本,360度无死角地呈现了一家公司从初创到惊艳到立足再到稳定的全过......一起来看看 《让大象飞》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

html转js在线工具
html转js在线工具

html转js在线工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试