js基石之---易读、易复用、易重构的 JavaScript 代码规范
易读、易复用、易重构的 JavaScript 代码规范
1.变量命名规范有意义
Bad: const yyyymmdstr = moment().format("YYYY/MM/DD");
Good: const currentDate = moment().format("YYYY/MM/DD");
2. 给变量定义名字
Bad: // What the heck is 86400000 for?
setTimeout(blastOff, 86400000);
Good: // Declare them as capitalized named constants.
const MILLISECONDS_IN_A_DAY = 86_400_000; setTimeout(blastOff, MILLISECONDS_IN_A_DAY);
3.函数的变量定义初始值
Bad: function createMicrobrewery(name) {
const breweryName = name || "Hipster Brew Co.";
// ...
}
Good: function createMicrobrewery(name = "Hipster Brew Co.") {
// ...
}
4.函数的形参过多时候,用对象代替多个参数
Bad: function createMenu(title, body, buttonText, cancellable) {
// ...
} createMenu("Foo", "Bar", "Baz", true);
Good: function createMenu({ title, body, buttonText, cancellable }) {
// ...
} createMenu({
title: "Foo",
body: "Bar",
buttonText: "Baz",
cancellable: true
});
5.函数应该只做一件事情
Bad: function emailClients(clients) {
clients.forEach(client => {
const clientRecord = database.lookup(client);
if (clientRecord.isActive()) {
email(client);
}
});
}
Good: function emailActiveClients(clients) {
clients.filter(isActiveClient).forEach(email);
} function isActiveClient(client) {
const clientRecord = database.lookup(client);
return clientRecord.isActive();
}
6.函数名称应该说明其作用
Bad: function addToDate(date, month) {
// ...
} const date = new Date(); // It's hard to tell from the function name what is added
addToDate(date, 1);
Good: function addMonthToDate(month, date) {
// ...
} const date = new Date();
addMonthToDate(1, date)
7.使用Object.assign拷贝对象
Good: const menuConfig = {
title: "Order",
// User did not include 'body' key
buttonText: "Send",
cancellable: true
}; function createMenu(config) {
config = Object.assign(
{
title: "Foo",
body: "Bar",
buttonText: "Baz",
cancellable: true
},
config
); // config now equals: {title: "Order", body: "Bar", buttonText: "Send", cancellable: true}
// ...
} createMenu(menuConfig);
8.开闭原则
对扩展开放,对修改关闭;
面向对象开发
9.函数的继承
class Animal {
constructor(age) {
this.age = age;
} move() {
/* ... */
}
} class Mammal extends Animal {
constructor(age, furColor) {
super(age);
this.furColor = furColor;
} liveBirth() {
/* ... */
}
} class Human extends Mammal {
constructor(age, furColor, languageSpoken) {
super(age, furColor);
this.languageSpoken = languageSpoken;
} speak() {
/* ... */
}
}
10 链式编程 在每个函数的结尾返回this即可
(这种模式在JavaScript中非常有用,您可以在jQuery和Lodash等许多库中看到它。它使您的代码更具表现力,并且不再那么冗长。出于这个原因,我说,使用方法链接并查看代码的干净程度。在类函数中,只需this
在每个函数的末尾返回即可,然后可以将更多的类方法链接到该函数上。)
class Car {
constructor(make, model, color) {
this.make = make;
this.model = model;
this.color = color;
} setMake(make) {
this.make = make;
// NOTE: Returning this for chaining
return this;
} setModel(model) {
this.model = model;
// NOTE: Returning this for chaining
return this;
} setColor(color) {
this.color = color;
// NOTE: Returning this for chaining
return this;
} save() {
console.log(this.make, this.model, this.color);
// NOTE: Returning this for chaining
return this;
}
} const car = new Car("Ford", "F-150", "red").setColor("pink").save();
11.async/await 来处理异步编程
参考地址来源 :https://github.com/ryanmcdermott/clean-code-javascript
js基石之---易读、易复用、易重构的 JavaScript 代码规范的更多相关文章
- 五分钟带你读懂 堆 —— heap(内含JavaScript代码实现!!)
一.概念 说起堆,我们就想起了土堆,把土堆起来,当我们要用土的时候,首先用到最上面的土.类似地,堆其实是一种优先队列,按照某种优先级将数字"堆"起来,每次取得时候从堆顶取. 堆 ...
- JS Nice – JavaScript 代码美化和格式化工具
JS Nice 是一款让经过混淆处理的 JavaScript 代码可读更好的工具.它使用一种新型的用于 JavaScript 代码美化的去混淆和去压缩引擎.JSNice 采用先进的机器学习和程序分析技 ...
- JavaScript必备:Google发布的JS代码规范(转)
[翻译]关于Google发布的JS代码规范,你需要了解什么? 翻译 | WhiteYin 译文 | https://github.com/WhiteYin/translation/issues/10 ...
- 谷歌与Airbnb的JS代码规范
谷歌JS代码规范 规范代码原因:代码规范是为了保持源代码编写模式一致,便于维护代码,可读性高. 1.使用空格代替tab 规范随后指出应该使用2个,而不是4个空格带实现缩进.(除了每一行的终止符序列,A ...
- 关于多本小说站的SEO—从”易读中文网”获得的心得体会
从目前国内的网站流量来说,电影站,小说站,游戏站等的流量占总流量的比例还是很高的,许多站长把目光投入到了这几个方面,本文就着重来说对于小说站,尤其是多本小说站的SEO心得体会! 对于小说站来说,只要排 ...
- markdown简易快速的编辑格式(易读易写)
实现简单快速书写,格式指定简便.易读易写 讲解http://wowubuntu.com/markdown/ 简单使用的讲解:http://www.ituring.com.cn/article/23 代 ...
- 如何让code变得更易读
从开始编码到现在,从没有意识去如何去写出更加规范,更加易读的代码,只是按照需求将某一功能进行实现.下面是最近在网上搜索查看的一些通用的知识点,做一记录. 单一抽象层次 单一抽象层次是指一个函数或者方法 ...
- web设计_7_页面缺失图片或CSS的情况下仍然易读
1. 在任何可能使用背景图片的地方应设置同样的颜色的背景色. 防止图片不能加载的情况下,页面内容同样保持较好可读性. 例如文字为白色,背景图为深色,如果不设置背景色,当背景图未成功加载, 而浏览器多数 ...
- python自定义小工具:密码匿名化、毫秒时间显示、人类易读字节
import base64 import time def timestamp2datems(timestamp): ''' 时间戳转为日期字串,精确到ms.单位s :param timestamp: ...
随机推荐
- A - A FZU - 2205
A - A FZU - 2205 一个国家有 N 个城市,国王不希望国家中存在三个城市之间能够互相直接到达,但道路要求尽可能的多,道路是双向边,且无重边无自环. 国王希望你最好能解决这个问题.求最多存 ...
- U - Inviting Friends HDU - 3244( LIS 最长升序子序列——变形 )
序列变换 Problem Description 我们有一个数列A1,A2-An,你现在要求修改数量最少的元素,使得这个数列严格递增.其中无论是修改前还是修改后,每个元素都必须是整数. 请输出最少需要 ...
- 《快速认识 Three.js 》
此文仅作备份之用,为了更好的阅读体验,建议访问原文链接:<Three.js - 走进3D的奇妙世界.> ,感谢原作者的好文.
- C语言一行语句太长的换行处理方法
[toc] 1.C语言中代码的多行书写 对C语言初学者来说,编写的程序的功能很简单,一句代码很短,但是在实际开发中,参数往往很长很多,一句代码可能会很长,需要用多行才能书写. 如果我们在一行代码的行尾 ...
- js中相关的windows方法的使用和location的先关方法的使用
下面是关于windows的相关方法的简单介绍. setInterval():它有一个返回值,主要是提供给clearInterval使用. setTimeout():它有一个返回值,主要是提供给clea ...
- 关于android中数据库的创建以及基础的增删改查的相应操作
这里主要是掌握一些基本的相应的知识,具体的是阿金是等到明天在进行. 相应的知识点如下: 对于数据库中的一些常识.SQLite 没有服务器进程,它通过文件保存数据,该文件是跨平台的,可以放在其他平台中使 ...
- jvm入门及理解(一)——简介与体系架构
最近,在学习java虚拟机的内容中,在此总结和记录下学到的. 一.JVM在计算机中的位置 在我们初学java时,便知道java源文件文件会先通过Java编译器编译成字节码文件,这个过程是java编译过 ...
- CSS 布局水平 & 垂直对齐
元素居中对齐 margin: auto; 文本居中对齐 text-align: center; 图片居中对齐 要让图片居中对齐, 可以使用 margin: auto; 并将它放到 块 元素中 左右对齐 ...
- Linux CentOS7 开通端口外网端口访问权限
一.查看系统防火墙状态(如果返回 running 代表防火墙启动正常)firewall-cmd --state二.开启端口外网访问1.添加端口 返回 success 代表成功(--permanent永 ...
- Powershell如何制定属性并输出
这个标题看着有些云里雾里.... 前一阵,群里有个朋友问博主“我想把所有用户的SMTP地址全部输出到CSV文件中进行统计,但是SMTP地址似乎输出的是错误的,可在shell里看输出的内容是正确的阿” ...