写出良好风格的JS、CSS代码
现在代码的格式都有 eslint、prettier、babel 这些来保证,但是技术手段再高端都不能解决代码可读性的问题。
因为这个只有个人才能解决。但是注意一下事项,可以显著提高代码的可读性、可识别性。
一、变量相关
1、限量数量的定义。
不要滥用变量,数据只使用一次或者不使用就无需装到变量中。
let kpi = 4; // 没用的就删掉
function example() {
let a = 1;
let b = 2;
return 2*a + b + 1;
}
2、变量命名
无需对每个变量都写注释,从名字上就看懂。
// 不要
let fName = 'guo';
let lName = 'zheng';
// 要这样
let firstName = 'guo';
let lastName = 'zheng';
3、特定的变量
if(value > 8) {
// 为什么要大于 8 ,8 表示什么?长度?位移?还是高度?
}
// 应为
const MAX_INPUT_LENGTH = 8;
if(value > MAX_INPUT_LENGTH) {
// 一目了然
}
4、变量命名
// 过于啰嗦
let nameString;
let theUsers;
// 要简洁
let name;
let users;
5、使用说明性的变量 -- 即 有意义的变量
const address = 'One Infinite Loop, Cupertino 95014';
const cityZipCodeRegex = /^[^,\\]+[,\\\s]+(.+?)\s*(\d{5})?$/;
saveCityZipCode(
address.match(cityZipCodeRegex)[1], // 这个公式要干嘛?
address.match(cityZipCodeRegex)[2], // 这个公式要干嘛?
)
// 用变量名解释长代码的含义
const address = 'One Infinite Loop, Cupertino 95014';
const cityZipCodeRegex = /^[^,\\]+[,\\\s]+(.+?)\s*(\d{5})?$/;
const [, city, zipCode] = address.match(cityZipCodeRegex) || []; // 解构赋值
saveCityZipCode(city, zipCode)
6、避免使用太多全局变零
少用或者使用替代方案。
你可以选择只用局部变量,通过(){} 的方法。
如果确实有很多的全局变量需要共享,你可以使用vuex,redux 或者 自己参考 flux 模式写一个。
7、变量赋值
对于求职获取的变量,做好兜底。
// 没有兜底
const MIN_NAME_LENGTH = 8;
let lastName = fullName[1];
if(lastName.length > MIN_NAME_LENGTH) {
// 这样就给代码埋了一个坑。当fullName 为一个元素时呢? 比如:fullName = ['guo']
}
// 做好兜底
const MIN_NAME_LENGTH = 8;
let lastName = fullName[1] || '';
if(lastName.length > MIN_NAME_LENGTH) {
...
}
// 其实在项目中很多求值变量,对于每个求值变量都需要做好兜底
let propertyValue = Object.attr || 0; // 因为 Object.attr 有可能为空,所以要做好兜底。但是变量赋值不需要兜底。
二、函数相关
1、函数命名
对于返回 true 或 false 的函数,最好以 should、is、can、has 开头
function showFriendsList() {} // 现在问,返回的是一个数组,还是对象,还是 true or false。无法知道。
// 一目了然
function isEmpty() {}
function hasClass() {}
function canOpen() {}
function shouldShow() {}
2、功能函数最好为纯函数
不要让功能函数的输出变化无常。功能函数使用纯函数,输入一致,输出结果永远唯一。
function plusAbc(a, b, c) {
let c = fetch('../api'); // 因为 api 变化,输出变化。
return a + b + c;
}
// 纯函数
function plusAbc(a, b, c) {
return a + b + c;
}
3、函数传参
pageXOffset.getSVG(api, true, false); // 让人看不懂这三个参数
pageXOffset.getSVG({
imageApi: api,
includePageBackground: true,
compress: false
// 一目了然 知道这些参数是控制什么。
});
4、动作函数要以动词开头
function sendEmailToUser() {}; function getUserInfo() {};
5、一个函数完成一个独立功能,不要一个函数混杂多个功能。
当函数需要做更多事情时,他们会更难以编写、测试、理解、组合。当你能将一个函数抽离出来只完成一个动作,他们将更容易进行重构并且代码更容易阅读。
6、优先使用命令式编程。
// 使用for循环编程
for(var i=1;i<10;i++) {
// 每一项要做的事情
}
// 命令式
let b = a.map(item => {
// 每一项要做的事情
})
7、函数过多使用if else
可以使用switch 替代,或者数组 替代。参考上一篇。
三、尽量使用ES6, 有可能的话使用 ES7
1、使用箭头函数 代替传统函数
// 传统
function add() {}
// 箭头函数
let add = () => {}
2、连接字符串
使用模板字符串 代替 传统 +
// 传统
let str = 'hello' + name;
// 模板
let str = `hello${name}`
3、使用解构赋值
// 传统
let data = { name: 'guo', age: 11 };
let name = data.name;
let age = data.age; let fullName = ['guo', 'zheng'];
let firstName = fullName[0];
let lastName = fullName[1]; // 解构赋值
let data = { name: 'guo', age: 11 };
const {name, age} = data; let fullName = ['guo', 'zheng'];
const [firstName, lastName] = fullName;
4、尽量使用 class
不太会,以后再补
四、别处补充来
1、采用utf-8编码,在CSS头部使用。
@charset "utf-8"
必须定义在css文件所有字符前面(包括注释),才能生效
2、定义的选择器名,属性及属性值的书写皆为小写。
3、当一个规则包含多个选择器时,每个选择器独占一行。
+、~、> 选择器的两边各留一个空格
.header > .header-res,
.footer + .footer-res {}
4、选择器命名尽量 简洁且语义化
5、数值 与 单位
当属性值或颜色参数为 0 ---- 1 之间的数时,省略0
color: rgba(255, 255, 255, .6)
当长度为 0 时,省略单位,margin: 0 auto 20px;
十六进制颜色 使用小写且尽量简写。
样式属性的顺序:
如果包含content属性,应放在最前面。
布局方式、位置相关属性。position / top / right / bottom / left / z-index / display / float / …
盒模型相关属性。width / height / padding / margin / border / overflow / …
文本排版相关属性。font / line-height / text-align / word-wrap / …
视觉外观相关属性。color / background / list-style / transform / animation / transition / …
合理使用引号:在某些样式中,会出现一些含有空格的关键字或者中文关键字。
body { font-family: 'Microsoft YaHei', '黑体-简', '\5b8b\4f53'; }
div {
background-image: url('...');
}
避免使用 !important
尽量避免使用标签名。提高CSS匹配性能。CSS 选择器的解析规则: 从右到左。
仅作学习笔记,如有雷同不是巧合,可能是参考过。
写出良好风格的JS、CSS代码的更多相关文章
- 自写脚本实现上线前本地批量压缩混淆 js , css 代码。
最近做项目遇到一个要求,就是把本地的 js 和 css 进行压缩后再上线,由于之前项目并没有使用 webpack 之类的库,项目上也因为一些机密不能在线上压缩,这无疑给代码打包压缩带来了很大麻烦,于是 ...
- 写出gradle风格的groovy代码
写出gradle风格的groovy代码 我们先来看一段gradle中的代码: buildscript { repositories { jcenter() } dependencies { class ...
- 在Sublime Text 3 中安装SublimeLinter,Node.js进行JS&CSS代码校验
转载自:http://www.wiibil.com/website/sublimelinter-jshint-csslint.html 在Sublime Text中安装SublimeLinter,No ...
- Python推导式详解,带你写出比较精简酷炫的代码
Python推导式详解,带你写出比较精简酷炫的代码 前言 1.推导式分类与用法 1.1 列表推导 1.2 集合推导 1.3 字典推导 1.4 元组推导?不存在的 2.推导式的性能 2.1 列表推导式与 ...
- 如何写出同事看不懂的Java代码?
原创:微信公众号 码农参上,欢迎分享,转载请保留出处. 哈喽大家好啊,我是没更新就是在家忙着带娃的Hydra. 前几天,正巧赶上组里代码review,一下午下来,感觉整个人都血压拉满了.五花八门的代码 ...
- PyTorch最佳实践,怎样才能写出一手风格优美的代码
[摘要] PyTorch是最优秀的深度学习框架之一,它简单优雅,非常适合入门.本文将介绍PyTorch的最佳实践和代码风格都是怎样的. 虽然这是一个非官方的 PyTorch 指南,但本文总结了一年多使 ...
- 在SUBLIME TEXT中安装SUBLIMELINTER进行JS&CSS代码校验
一:Sublime Text 中需要先安装Package Control.(如果有则无需安装) 安装方法:打开Sublime Text控制台(快捷键Ctrl+`),在控制台粘贴以下代码,按回车执行. ...
- 写出优雅又地道的pythonic代码(转自网络)
本文是Raymond Hettinger在2013年美国PyCon演讲的笔记(视频, 幻灯片). 示例代码和引用的语录都来自Raymond的演讲.这是我按我的理解整理出来的,希望你们理解起来跟我一样顺 ...
- 如何写出优雅又地道的Python代码?【转载】
在Python社区文化的浇灌下,演化出了一种独特的代码风格,去指导如何正确地使用Python,这就是常说的pythonic.一般说地道(idiomatic)的python代码,就是指这份代码很pyth ...
随机推荐
- Python多进程并发操作中进程池Pool的应用
Pool类 在使用Python进行系统管理时,特别是同时操作多个文件目录或者远程控制多台主机,并行操作可以节约大量的时间.如果操作的对象数目不大时,还可以直接使用Process类动态的生成多个进程,十 ...
- git教程: 查看文件状态与修改内容
转载:时光机穿梭 我们已经成功地添加并提交了一个readme.txt文件,现在,是时候继续工作了,于是,我们继续修改readme.txt文件,改成如下内容: Git is a distributed ...
- Spring boot JPA 用自定义主键策略 生成自定义主键ID
最近学习Spring boot JPA 学习过程解决的一些问题写成随笔,大家一起成长.这次遇到自定义主键的问题 package javax.persistence; public enum Gener ...
- 几个特殊的IP地址
1)私有地址 IP地址在全世界范围内唯一,看到这句话你可能有这样的疑问,像192.168.0.1这样的地址在许多地方都能看到,并不唯一,这是为何?Internet管理委员会规定如下地址段为私有 ...
- s21day06 python笔记
s21day06 python笔记 一.昨日内容回顾及补充 回顾 补充 列表独有功能 reverse:反转 v = [1,2,3,4,5] v.reverse() #[5,4,3,2,1] sort: ...
- MySQL 5.7以上 root用户默认密码问题【转】
https://www.yanning.wang/archives/379.html 废话少说一句话系列: CentOS系统用yum安装MySQL的朋友,请使用 grep "temporar ...
- PythonStudy——逻辑运算符 Logical Operators
在Python中,None.任何数值类型中的0.空字符串“”.空元组().空列表[].空字典{}都被当作False,还有自定义类型,如果实现了 __ nonzero __ () 或 __ len __ ...
- (拼接SQL语句)mysql中date类型,datetime类型
: , . _ - / % & # @ ! * | [ ] { } ; + = update ky set date = '18,9-2' where id = 1 // 2 ...
- Python Django orm操作数据库笔记之外键和表关系
外键 在MySQL中,表有两种引擎,一种是InnoDB,另外一种是myisam.如果使用的是InnoDB引擎,是支持外键约束的. 外键的使用 使用外键前需要先确保相应外键已存储在数据库中(flask中 ...
- [转]马上2018年了,该不该下定决心转型AI呢
转自:http://blog.csdn.net/eNohtZvQiJxo00aTz3y8/article/details/78941013 2017年,AI再一次迈向风口,但我们如何判断未来走向?应不 ...