您好!
欢迎来到京东云开发者社区
登录
首页
博文
课程
大赛
工具
用户中心
开源
首页
博文
课程
大赛
工具
开源
更多
用户中心
开发者社区
>
博文
>
京东快递APP的Flutter代码规范实践
分享
打开微信扫码分享
点击前往QQ分享
点击前往微博分享
点击复制链接
京东快递APP的Flutter代码规范实践
自猿其说Tech
2021-11-11
IP归属:未知
269680浏览
Flutter
计算机编程
### 1 起源 做为跨平台的移动端解决方案,Flutter大大提高了移动端的开发效率,但是由于很多Flutter开发者原来都做了很多年的原生iOS或者Android开发甚至Web开发,后来才转而成为Flutter开发者,而移动端的原生开发语言OC/Swift/Java/Kotlin的代码规范千差万别,大家写代码的习惯也千差万别。那如何在Flutter开发过程中,统一代码规范,提高代码质量就是一个不小的问题。 ### l2 Dart lints Flutter的开发语言Dart有官方的代码静态检查工具—lints,同时lints中内置了上百条的代码规范,这些规范类别包括:可能的拼写错误、代码风格和代码的布局等等。而所以这些规范大致又可以分为两类:Core lints(核心规范)、Recommended lints(推荐规范)。 - Core lints:帮助识别出可能在代码运行时带来严重问题的代码。因此,所有的代码应该都通过这些代码规范检查。 - Recommended lints:Recommended lints包含Core lints,除了Core lints的检查规则外,Recommended lints主要是为了规范代码的风格和布局,让开发者以同一种风格来开发Dart工程。 除了预定义的这两种规范,开发者还可以在lints中添加自己的规范。 ### 3 Flutter lints 虽然Dart有自己的代码检查规范,但是Flutter官方更推荐开发者使用为了Flutter而定制的代码静态检查工具—flutter lints。Flutter lints中包含了一系列的开发Flutter app、package和plugin的推荐代码规范。他是在上面所说的Dart lints的Recommended lints的基础上进行的扩充和对Flutter的适配。 #### 3.1 集成Flutter lints 对于在使用Flutter 2.3.0以上的SDK通过flutter creat命令创建的Flutter app、package和plugin中,flutter lints默认会集成到工程代码里。 而对于已经存在的Flutter 工程来说,集成flutter lints也是非常简单的。 1)在Flutter工程的目录下,运行如下命令 ``` flutter pub add –dev flutter_lints ``` 2)在flutter工程的根目录下创建一个名为analysis_option.yaml的文件,并且在文件中输入 ``` include: package:flutter_lints/flutter.yaml ``` 下面就是默认的analysis_option.yaml文件的例子: ![](//img1.jcloudcs.com/developer.jdcloud.com/e7d94861-6b0f-49a4-baac-4224937e571720211111121641.png) #### 3.2 增加规则 除了使用flutter lints中的默认规则,开发者也可以增加一些规则,常见的规则如下面的链接中可以看到,https://joyspace.jd.com/page/bqNsFfEadKyqxF0PRaCw。 这些规则中,可能有些规则之间是相互冲突的。某些规则可能更适合于package的开发者,有些可能更适合于flutter app的开发者。 在默认的情况下,代码检查的规则如下: ``` include: package:lints/recommended.yaml linter: rules: - avoid_print - avoid_unnecessary_containers - avoid_web_libraries_in_flutter - no_logic_in_create_state - prefer_const_constructors - prefer_const_constructors_in_immutables - prefer_const_declarations - prefer_const_literals_to_create_immutables - sized_box_for_whitespace - use_full_hex_values_for_flutter_colors - use_key_in_widget_constructors ``` 也就是Dart的recommended规则增加了11项,如果开发者想要增加规则,只需要在analysis_option.yaml文件中的rules中,增加规则名称,并设置为true。例如: ``` prefer_single_quotes: true ``` #### 3.3 删除规则 同样也可以删除默认的规则中的某些规则,或者让他不起效,只需要在analysis_option.yaml文件中的rules中,增加规则名称,并设置为false。例如: ``` avoid_print: false ``` #### 3.4 将文件排除在代码检查之外 同样我们可以将某些文件排除在代码规则检查之外,我们可以在analyzer中添加exclude,例如: ``` analyzer: exclude: - lib/client.dart - lib/server/*.g.dart - test/_data/** ``` ### 4 京东快递的代码规则实践 在Flutter lints的默认规则下,我们发现了不少代码问题,特别是因为我们的代码刚迁移到Flutter 2.0的空安全,其中不少和空安全或者Dart的新的语法有关。只需要在代码的根目录下运行命令 dart analyze ,我们就可以看到京东快递APP中的常见的违反代码规则的地方: **不必要的冗余代码:** 1. 创建类的实例不需要使用new(unnecessary_new) 1. 除了防止被覆盖,使用类的属性时,不需要使用this来修饰 1. 在对象不可能为null的情况下,不需要使用非空判断(主要来源于空安全的转换过程中,有些无用代码未被删除) **Dart 2.0的新规则的采用:** 1. 在函数中应该使用=将命名参数和他的默认值分开,而在Dart 2.12之前一直是使用冒号(:) 1. 使用isEmpty来判断集合中是否存在元素,而不是使用length 1. 函数的集合类型的入参应该明确指出集合中的对象类型 1. 在async函数中,调用返回Future的方法时,必须要在调用前明确指出,是await还是unawait 1. 避免在forEach中使用简写函数字面量,而是应该使用for( in ) 1. 应该总是在函数中定义函数的返回类型 在刚开始制定代码规范的时候,默认的代码规范已经能满足我们的基础需求了。但是随着开发的不断深入,规则需要随之而进行不断的完善和改进,删除很多并不必要的规则。制定代码规范不是为了制定规范而规范,而是为了提高代码质量和代码的可维护性。规则制定完之后,当然就需要尽最大的努力保证规则的执行。目前我们也在考虑在CI中加入代码规范的检查。通过持续集成快速检测,实时将结果反馈给代码的对应负责人,降低规范落地的成本。代码是研发团队的核心资产,需要我们共同守护。 ##### 参考文献 https://dart.dev/tools#ides-and-editors https://dart-lang.github.io/linter/lints/index.html https://dart.dev/guides/language/analysis-options https://dart.dev/tools/linter-rules https://dart.dev/guides/language/analysis-options ------------ ###### 自猿其说Tech-JDL京东物流技术发展部 ###### 作者:快递快运技术部 郝宏伟
原创文章,需联系作者,授权转载
上一篇:聊一聊JUC中的“借助同步”
下一篇:深入了解SPI插件机制
相关文章
【技术干货】企业级扫描平台EOS关于JS扫描落地与实践!
Flutter异步编程中Completer的使用
聊一聊多线程不得不知的Future(一)
自猿其说Tech
文章数
426
阅读量
2149964
作者其他文章
01
深入JDK中的Optional
本文将从Optional所解决的问题开始,逐层解剖,由浅入深,文中会出现Optioanl方法之间的对比,实践,误用情况分析,优缺点等。与大家一起,对这项Java8中的新特性,进行理解和深入。
01
Taro小程序跨端开发入门实战
为了让小程序开发更简单,更高效,我们采用 Taro 作为首选框架,我们将使用 Taro 的实践经验整理了出来,主要内容围绕着什么是 Taro,为什么用 Taro,以及 Taro 如何使用(正确使用的姿势),还有 Taro 背后的一些设计思想来进行展开,让大家能够对 Taro 有个完整的认识。
01
Flutter For Web实践
Flutter For Web 已经发布一年多时间,它的发布意味着我们可以真正地使用一套代码、一套资源部署整个大前端系统(包括:iOS、Android、Web)。渠道研发组经过一段时间的探索,使用Flutter For Web技术开发了移动端可视化编程平台—Flutter乐高,在这里希望和大家分享下使用Flutter For Web实践过程和踩坑实践
01
配运基础数据缓存瘦身实践
在基础数据的常规能力当中,数据的存取是最基础也是最重要的能力,为了整体提高数据的读取能力,缓存技术在基础数据的场景中得到了广泛的使用,下面会重点展示一下配运组近期针对数据缓存做的瘦身实践。
自猿其说Tech
文章数
426
阅读量
2149964
作者其他文章
01
深入JDK中的Optional
01
Taro小程序跨端开发入门实战
01
Flutter For Web实践
01
配运基础数据缓存瘦身实践
添加企业微信
获取1V1专业服务
扫码关注
京东云开发者公众号