当前位置: 首页 > wzjs >正文

如何对网站做镜像武汉网站建设公司

如何对网站做镜像,武汉网站建设公司,网站关键词互点,网站的类别近日,在 Dart 3.8 的 changelog 里正式提交了 Null-Aware Elements 语法,该语法糖可以用于在 List、Set、Map 等集合中处理可能为 null 的元素或键值对,简化显式检查 null 的场景: /之前 var listWithoutNullAwareElements [if …

近日,在 Dart 3.8 的 changelog 里正式提交了 Null-Aware Elements 语法,该语法糖可以用于在 List、Set、Map 等集合中处理可能为 null 的元素或键值对,简化显式检查 null 的场景:

/之前
var listWithoutNullAwareElements = [if (promotableNullableValue != null) promotableNullableValue,if (nullable.value != null) nullable.value!,if (nullable.value case var value?) value,
];/之后
var listWithNullAwareElements = [?promotableNullableValue,?nullable.value,?nullable.value,
];

自然,在 Flutter 的 UI 声明里,也可以简化之前控件的 if 判断,不得不说确实比起之前的写法优雅不少:

/之前
Stack(fit: StackFit.expand,children: [const AbsorbPointer(),if (widget.child != null) widget.child!,],
)/之后
Stack(fit: StackFit.expand,children: [const AbsorbPointer(),?widget.child,],
)

同时,官方在分析了大量开源 Dart 代码后(90019 个文件中的 17,941,439 行代码),发现这类需要支持的场景更多是 Map

-- Surrounding collection (1812 total) --1566 ( 86.424%): Map   ===============================================241 ( 13.300%): List  ========5 (  0.276%): Set   =

而事实上,从以下例子可以看出来,在简化 Map 上 Null-Aware Elements 的作用尤为明显:

/之前
final tag = Tag()..tags = {if (Song.title != null) 'title': Song.title,if (Song.artist != null) 'artist': Song.artist,if (Song.album != null) 'album': Song.album,if (Song.year != null) 'year': Song.year.toString(),if (comments != null)'comment': comms!.asMap().map((key, value) => MapEntry<String, Comment>(value.key, value)),if (Song.numberInAlbum != null) 'track': Song.numberInAlbum.toString(),if (Song.genre != null) 'genre': Song.genre,if (Song.albumArt != null) 'picture': {pic.key: pic},}..type = 'ID3'..version = '2.4';/之后
final tag = Tag()..tags = {'title': ?Song.title,'artist': ?Song.artist,'album': ?Song.album,'year': ?Song.year?.toString(),if (comments != null)'comment': comms!.asMap().map((key, value) => MapEntry<String, Comment>(value.key, value)),'track': ?Song.numberInAlbum?.toString(),'genre': ?Song.genre,if (Song.albumArt != null) 'picture': {pic.key: pic},}..type = 'ID3'..version = '2.4';

通过下面的简单例子,也可以看出来有了 Null-Aware Elements 之后在代码简化效果上很明显:

当然,配合其他语法也能达到去 null 的效果,比如最简单的 for 循环,通过 ?i ,就可以简单到做排除空数据的目的:

当然,你可能会觉得本来 Dart 里就有很多 ? ,比如 ?? 、 ?. 之类,加上语法之后会不会有歧义?这个问题在目前的规则上看起来还行,例如此时的 ? 前通常是 ,[{ : 等符号,这些上下文和现有 ? 用法不同 :

var list = [1, ?foo]; // ? 是空感知元素,不是其他用法
var map = {key: ?value}; // ? 是空感知值,不是可空类型

并且前面介绍过,与现有语法如 iffor 元素结合时,? 出现在 if for 头部后也不会有歧义:

var list = [for (var i in [1, 2]) ?i, // 合法:?i 是空感知元素
];
print(list); // 输出: [1, 2]

而在 Flutter 里的 UI 编排了就更加直观了:

当然,这个语法还是有一些规则限制,在这个规则下 expression 只能是一个普通表达式,不能是另一个集合,比如嵌套的 ? 或展开操作 ...

element ::=| nullAwareExpressionElement| nullAwareMapElement| // Existing productions...nullAwareExpressionElement ::= '?' expressionnullAwareMapElement ::=| '?' expression ':' '?'? expression // Null-aware key or both.|     expression ':' '?' expression  // Null-aware value.

例如下方代码就可以很直观展示这个错误使用,同时也没有 ????foo?if (c) nullableThing else otherNullableThing 这样的场景:

可以看到, Null-aware elements 语法不管是在逻辑代码还是 UI 代码都十分有用,虽然 Dart 3.8 还没正式发布,但是你可以在 Flutter beta channel 提前体验,那么,你觉这个语法符合你的审美吗?

参考链接

  • https://github.com/dart-lang/language/blob/main/accepted/future-releases/0323-null-aware-elements/feature-specification.md
http://www.dtcms.com/wzjs/476853.html

相关文章:

  • 在线代理app页面关键词优化
  • 门业网站 源码b站视频推广网站
  • 沈阳市网站建设报价品牌营销案例
  • wordpress 全局变量深圳专门做seo的公司
  • html5网站是用什么软件做的吗福建seo快速排名优化
  • 做彩票平台网站吗seo排名优化推广报价
  • 做软件下载网站怎么赚钱广东省最新新闻
  • 做app_需要先做网站吗百度推广公司哪家比较靠谱
  • wordpress模板替换武汉网站seo推广公司
  • 深圳网站建设-中国互联怎么优化一个网站
  • wordpress站点演示网站推广的目的是什么
  • 智能小程序开发报价seo模拟点击算法
  • 网站上怎么做企业推广百度网页版下载
  • 地方o2o同城网站源码百度贴吧网页版登录入口
  • 90后做受网站9个广州seo推广神技
  • 什么是网络营销?请写出其定义网站如何优化关键词排名
  • 网站后台图片不显示关键词点击价格查询
  • php网站开发做什么seo主要优化哪些
  • 山东饰品行业网站制作seo是什么单位
  • 介绍婚纱网站的ppt怎么做网页制作公司
  • 应式网站百度精简版入口
  • 网站文件保护怎么做sem是什么意思啊
  • 网站建设试用企业培训方案
  • 中国工程机械网官网北京seo怎么优化
  • 物流网站建设哪个好谷歌seo和百度seo区别
  • 网站建设资讯版块如何做用户运营黄页推广引流网站
  • 重庆沙坪坝地图如何进行关键词优化工作
  • 重庆无障碍网站建设百度网站快速排名公司
  • 星光影视园网站建设案例云资源软文发布平台
  • 99到家网站怎么做百度高级搜索技巧