写出良好风格的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 ...
随机推荐
- 王者荣耀交流协会第5次Scrum立会
开会时间:2017年10月31日下午18:00-18:31 共计31分钟 开会地点:一食堂二楼靠近窗户倒数第四排 今日完成工作进度: 王超同学完成了将生成饼状图原型整合到程序中 立会内容: 添加了新 ...
- 【转】@RequestBody注解出现的三点错误
错误1 { "timestamp": 1529747704259, "status": 415, "error": ...
- python 5
一.python2与3的差别 在2中,range是一个数字列表 xrange是一个可迭代对象 在3中,range是一个可迭代对象 没有xrange 二.dict dict长什么样? 一个key对应一个 ...
- 洛谷P1605:迷宫(DFS)
题目背景 迷宫 [问题描述] 给定一个N*M方格的迷宫,迷宫里有T处障碍,障碍处不可通过.给定起点坐标和终点坐标,问: 每个方格最多经过1次,有多少种从起点坐标到终点坐标的方案.在迷宫中移动有上下左右 ...
- .NET平台
.nat 是一种跨语言的平台 类跟对象回顾 由于对象归纳类 是归纳对象共性的过程 在类似的基础上 将状态和行为实体话为对象的过程称为实例话 只写属性 只包含set访问器 只读属性 只包含get ...
- webpack学习笔记(三)
访问网址: https://github.com/webpack/analyse "scripts": { "dev-build": "webpack ...
- TreeSet的两种排序方式,含Comparable、Comparator
1.排序的引入 由于TreeSet可以实现对元素按照某种规则进行排序,例如下面的例子 public class TreeSetDemo { public static void main(String ...
- new 对象时的暗执行顺序
为什么称为暗执行顺序,因为当我们在new 对象时,其不是简简单单的new一个完事,它要首先检查父类的,静态的,非静态的等代码,就好像我们结婚生孩子一样,要先到祖宗那里,公安局那里,左邻右舍那里,告诉他 ...
- 在Docker中监控Java应用程序的5个方法
译者注:Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化.通常情况下,监控的主要目的在于:减少宕机 ...
- 使用docker compose编排容器
一.安装docker compose 二进制包安装 1.安装 Docker Compose 从 官方 GitHub Release 处直接下载编译好的二进制文件即可 # curl -L https:/ ...