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: ...
随机推荐
- Java线程及其实现方式
一.线程&多线程 线程: 线程是进程的一个实体,是 CPU 调度和分派的基本单位,它是比进程更小的能独立运行的基本单位.线程 自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序 ...
- springboot + aop + Lua分布式限流的最佳实践
整理了一些Java方面的架构.面试资料(微服务.集群.分布式.中间件等),有需要的小伙伴可以关注公众号[程序员内点事],无套路自行领取 一.什么是限流?为什么要限流? 不知道大家有没有做过帝都的地铁, ...
- Xmind pro Win10系统下安装问题解决与破解
Xmind pro Win10系统下安装问题解决与破解 1.下载安装版本 解压包含文件: xmind-8-update7-windows--安装包 和XMindCrack.jar--激活破解工具 2. ...
- C/C++知识总结 二 C/C++基础知识
C/C++基础知识 C/C++基本格式说明 C/C++基本常识说明 C/C++基本格式说明 C语言基本格式 #include<stdio.h> //预处理文件 int main() //自 ...
- XXE验证与利用流程
特征 特征1 --- .ashx 看到url是 .ashx后缀的 特征2 --- 响应体是xml 发现有这些特征都可以用下面的流程测试 测试 在线工具: http://ceye.io/ http:// ...
- 拿万元月薪必备的书单,学JAVA的程序员必看的5本书!
点击蓝色"程序员黄小斜"关注我哟 加个"星标",每天带你读好书! 文/黄小斜 转载请注明出处 每一年的年初都是买书学习热情高涨的时候,虽然不知道你们是让这些书吃 ...
- pssh远程套件工具
pssh远程套件工具 案例5:pssh远程套件工具 5.1问题 本案例要求使用pss ...
- javascript入门 之 ztree (十 checkbox选中事件)
<!DOCTYPE html> <HTML> <HEAD> <TITLE> ZTREE DEMO - beforeCheck / onCheck< ...
- javascript入门 之 ztree(五 自定义字体)
<!--<!DOCTYPE html>--> <!--<HTML>--> <!--<HEAD>--> <!--<TI ...
- itoa、ltoa
#include <stdlib.h> /*整形转字符型*/ char * itoa(int value, char *string, int radix) { char tmp[33]; ...