博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
flutter/dart 代码规范
阅读量:5935 次
发布时间:2019-06-19

本文共 2073 字,大约阅读时间需要 6 分钟。

前言

最近看qq群里发的很多代码截图,感觉命名规则/文件命名都不符合规范

很多朋友都是从其他语言转向dart/flutter的,深感语言环境还需要大家共同去维护,建议还是规范化代码,这样所有人看着都会舒服
恰好dart语言官方有自己的代码规范和相关的说明,在dartlang官网上,英文好的建议阅读原文
连接地址

我这里仅粗略翻译和加入一些自己的理解

图片均来自于上述url对应的页面中

当前dart版本为2.0版本,日期为2018年08月22日
可能会在未来有改动,到时请以最新文档为准

文档中图片的绿色部分为正例,右上角带good标识

红色是反例,右上角带bad标识

标识方案

在dart有3种常规标识方案

第一个为大写字母开头的驼峰式 如 UserInterface 每个词的首字母为大写
第二个是小写开头的驼峰式,如testRun,第一个单词是小写,后续每个单词首字母大写
第三个是每个单词均为小写,以下划线分隔,如user_response

总结

如果不想往下看具体的图片和翻译,直接看这里

文件名: 小写+下划线

类型名(类名,函数类型名):大写开头驼峰
变量名(包含const final 常量):使用小写开头驼峰, 项目有特殊要求 const可以使用大写+下划线的方式,如同java中一样
导包as后的名称为小写+下划线
不要用匈牙利命名法中的kXXXX 这样的命名方式,应该去掉k
超过两位的英文缩写一律按该单词为普通小写单词处理,使用小写

导包有顺序要求,且每"部分"间空行分隔开,每部分内按字母排序,按如下顺序排序

dart sdk内的库
flutter内的库
第三方库
自己的库
相对路径引用

先全部import再export,不要交替进行

使用dartfmt工具格式化dart文件代码 dartfmt -w lib/ flutter可以用flutter format lib

单行字符建议不要超过80个
流程控制语句无论如何都使用花括号包裹,即使只有单行

格式化个人建议:

建议不要使用idea/as/vscode 的自动储存格式化作为交付

因为idea/vs有自己的格式化工具,并不是使用的dartfmt,这样会造成代码交付格式不统一,写代码过程中可以使用以方便提高阅读性,但每次代码commit前建议使用 dartfmt -w lib/ 来格式化代码,以便于项目代码风格的统一,flutter用户使用 flutter format lib

类型名称

适用于类名,注解名,typedef定义的函数名

这里有一个特例,当你的注解是一个const的常量时,使用@foo的方式作为注解

库名称,文件名用小写+下划线

使用小写+下划线方式命名library,文件名

原因如下:

某些文件系统不区分大小写,因此许多项目要求文件名全部为小写。使用分隔字符允许名称仍以该形式可读。使用下划线作为分隔符可确保名称仍然是有效的Dart标识符

导入时

当导入包时, 如果涉及到as, 一律使用小写+下划线方式

其他标识符

包含顶级成员,类成员,方法内成员,参数名,命名参数名,一律使用小写驼峰式

常量名称

建议使用小写驼峰式命名

但是你的项目中如果使用大写+下划线分割单词的方式,则可以继续使用这种方式
这里有个小说明:最初dart中采用的大写+下划线方式,但是后来有一些变量需要修改为非const变量,就需要修改为小写驼峰式,后一律使用小写驼峰式

缩写相关

超过两位的使用常规方式,两位以内使用大写

在小写驼峰式中,会出现一些约定俗成的缩写,如http ftp io等,这些在英文词法中都应该是大写,但大写连续会破坏可读性,如HTTPSFTP,你不知道是HTTPS FTP 还是 HTTP SFTP,所以采用如上图绿色的方式来命名

不要使用前缀字母

匈牙利命名法中使用缩写开头的小写驼峰命名法时,是因为当时编辑器无法很好帮助理解你的代码,这样命名法能够很好的帮助你去理解代码,现在dart语言中,编辑器可以很好的通过声明等方式帮你理解你的代码,故,不要使用前缀字母,如上图绿色

规定代码的顺序


为了使文件保持整洁,我们有一个规定代码顺序。每个“部分”应该用空行分隔。

保证dart的导入顺序在所有其他包之前


保证带包名的引用方式在相对路径引用之前


首先import第三方的包

导入自己的包在后面一个单独的部分


全部导入完毕后,再export 导出


每个部分按字母顺序排序

格式化

使用dartfmt 程序来格式化代码

单行长度为80字符

可读性研究表明,长行文字难以阅读,因为当你移动到下一行的开头时,你的眼睛必须走得更远。这就是报纸和杂志使用多列文本的原因。

如果你真的发现自己想要超过80个字符的行,我们的经验是你的代码可能过于冗长而且可能更紧凑。主要罪犯通常是VeryLongCamelCaseClassNames。问问自己,“该类型名称中的每个单词是否告诉我一些关键或防止名称冲突?”如果不是,请考虑省略它。

流程控制使用花括号

转载地址:http://knjtx.baihongyu.com/

你可能感兴趣的文章
网络安全人才长期供不应求 北京需求占全国四分之一
查看>>
程序猿给马云提建议 阿里DT时代怎么走
查看>>
淘宝微信如何进入微信推广?
查看>>
极速闪存IBM FlashSystem一马当先
查看>>
王健林:没用的数据再大也照样死
查看>>
新华三Synergy塑合型基础架构为新经济提供强大引擎
查看>>
揭秘:海康威视的“棱镜门”不是弱密码问题
查看>>
数据中心停机中断真的是无法回避的现实吗?
查看>>
Linux基金会透露未来 Linux内核可能会引入形式验证
查看>>
用大数据失败案例的血泪教训来诉说8个不能犯的错误
查看>>
王垠:如何掌握所有的程序语言
查看>>
云如何帮助企业处理安全日志数据
查看>>
坐着编程变胖 站着编程伤膝盖
查看>>
“睡眠创业公司”——Casper意图颠覆床垫市场
查看>>
即将到来的高清视频时代,我们做好技术准备了吗?
查看>>
产品经理必会的五大数据分析模型
查看>>
MySpace出现史上最大规模数据泄露事件
查看>>
只要阅读两篇有关勒索软件的文章就可解锁!
查看>>
轻量级大规模机器学习算法库Fregata开源:快速,无需调参
查看>>
从蓝瘦“想哭”到 SELinux 看操作系统安全何在
查看>>