系列文章:
- [【手把手带你撸一个脚手架】第一步, 创建第一个命令](https://www.jianshu.com/p/17384daf707e)
- [【手把手带你撸一个脚手架】第二步, 搭建开发环境](https://www.jianshu.com/p/86553c641bf9)
- [【手把手带你撸一个脚手架】第三步, 获取 github 项目信息](https://www.jianshu.com/p/1c5bcc2856dc)
- [【手把手带你撸一个脚手架】第四步, 通过撸码获取项目信息](https://www.jianshu.com/p/b15ea26e6d0b)
- [【手把手带你撸一个脚手架】第五步, 撸完收工](https://www.jianshu.com/p/1d764b4f22e2)
> 工欲善其事, 必先利其器. 一个好的开发环境能让你事半功倍. 大家一起来, 把刀磨快加油干 ^_^
![2018-11-14-19-32-30](https://user-gold-cdn.xitu.io/2018/11/14/167126fe1ee73e66?w=796&h=552&f=png&s=541825)
## 配置 eslint 开启 vscode 自动修复
### 配置 eslint
- 首先, 安装 `eslint`
```shell
npm i eslint -D
```
- 其次, 初始化 `eslint` 在项目的根目录下执行 `./node_modules/.bin/eslint --init`
- 在命令行提示中选择第一个 `Use a popular style guide` 回车
![2018-11-14-19-46-19](https://user-gold-cdn.xitu.io/2018/11/14/167126fe1721068b?w=898&h=162&f=png&s=38156)
- 接下来的提示中, 仍然选择第一个 `Airbnb`, 相对严格
![2018-11-14-19-47-18](https://user-gold-cdn.xitu.io/2018/11/14/167126fe1f101f7a?w=952&h=132&f=png&s=35432)
- `Do you use React?` 写 `n`然后回车.
- 配置文件格式选择默认即可
![2018-11-14-19-49-07](https://user-gold-cdn.xitu.io/2018/11/14/167126fe1a46a64d?w=1038&h=124&f=png&s=21197)
- 设置完配置文件格式以后, eslint 会自动检测依赖这里我们直接回车就可以啦~
![2018-11-14-19-51-15](https://user-gold-cdn.xitu.io/2018/11/14/167126fe1a2c4f9e?w=1346&h=178&f=png&s=41385)
- 下一步, 等
![6af89bc8gw1f8o4qytrlrg203c052jro](https://user-gold-cdn.xitu.io/2018/11/14/167126fe1d8b7003?w=120&h=182&f=gif&s=21081)
- 下一步, 编辑器安装 `eslint` 插件
![2018-11-14-20-05-30](https://user-gold-cdn.xitu.io/2018/11/14/167126fe517e24ad?w=1588&h=1554&f=png&s=595652)
- 安装完成后重启编辑器, 我们把示例代码行尾的封号去掉后发现编辑器已经标红, 说明 eslint 已经能够正常工作. 配置成功, 是不是心跳蹦蹦迪~
![2018-11-14-20-07-42](https://user-gold-cdn.xitu.io/2018/11/14/167126fee7943a8d?w=830&h=148&f=png&s=26171)
![9150e4e5gy1fsj2tgx3nwg205a05agmg](https://user-gold-cdn.xitu.io/2018/11/14/167126fe518b89f7?w=190&h=190&f=gif&s=41432)
### 开启 vscode 自动修复
> 通过上一步的配置我们已经能够让编辑器识别出我们代码中不规范的地方, 但是还不够. 既然编辑器能够识别出错误, 它要是还能修正错误岂不是爽死
- 第一步, 打开 vscode 配置文件 `command + ,`
- 第二步, 在功能搜索框中输入 `autofix`
- 第三步, 按照如下图所示的方式配置.
![2018-11-14-20-02-49](https://user-gold-cdn.xitu.io/2018/11/14/167126fee982c5ea?w=956&h=450&f=png&s=44344)
至此, 我们的编辑器已经可以自动修复 eslint 中发现的 **代码规范** 相关的一些错误啦, 就像下边酱紫.
![zidongxiufu12113124](https://user-gold-cdn.xitu.io/2018/11/14/167127f46cb91ea0?w=587&h=89&f=gif&s=20900)
删除封号以后, 保存编辑器自动把封号给我们加上啦, 开发体验 666, 爽到飞起 ^_^
![9150e4e5ly1fw8irvg1ofg20ao0dckjm](https://user-gold-cdn.xitu.io/2018/11/14/167126feea578e24?w=384&h=480&f=gif&s=2741982)
ps: 至此, vscode 配置自动修复功能完成, 告诉你个秘密, `vue react` 都可以自动修复的哟, 有兴趣的小伙伴请评论区交流~
### 兼容 es6
> 现代的前端开发人员, es6 已经成为了刚需, 然鹅, node 对 es6 并没有完全兼容(到目前为止), 为了全方位使用最新的语法. 我们引入 babel
首先, 安装依赖
```shell
npm i @babel/core@7.1.6 babel-core@^6.26.3 babel-plugin-transform-es2015-modules-commonjs@6.26.2 babel-polyfill@6.26.0 babel-preset-env@1.7.0 babel-preset-latest-node@2.0.2 babel-register@6.26.0 -S
```
在项目的根目录中添加 `.babelrc` 在该文件中粘贴以下内容
```js
{
"presets": ["env"],
"plugins": ["transform-es2015-modules-commonjs"]
}
```
创建入口文件 `index.js` 并粘贴以下内容
```js
require('babel-register');
const babel = require('@babel/core');
const babelPresetLatestNode = require('babel-preset-latest-node');
babel.transform('code();
', {
presets: [[babelPresetLatestNode, {
target: 'current',
}]],
});
require('babel-polyfill');
require('./src');
```
创建 `src` 目录, 并添加 index.js a.js 文件, 文件内容如下
【【手把手带你撸一个脚手架】第二步|【手把手带你撸一个脚手架】第二步, 搭建开发环境】```js
// index.js
import a from './a';
a.a();
// a.js
export default {
a() {
console.log('12345');
},
};
```
此时执行 `node index.js` 顺利打印出 12345
![2018-11-14-21-25-25](https://user-gold-cdn.xitu.io/2018/11/14/167126feeca185a0?w=658&h=64&f=png&s=16006)
最后改造 `bin/learn.js` 内容如下:
```js
#!/usr/bin/env node
require('../');
// 执行入口文件
```
此时在命令行中执行 learn
![2018-11-14-21-29-25](https://user-gold-cdn.xitu.io/2018/11/14/167126ff2b56b7d9?w=610&h=60&f=png&s=13138)
兼容 es6 成功
到目前为止, 我们的开发环境搭建完成. 撒花庆祝 ^_^
![6af89bc8gw1f8swu2wk2tg2046046gnj](https://user-gold-cdn.xitu.io/2018/11/14/167126ff120e3af5?w=150&h=150&f=gif&s=81374)
下集预告: 下一节, 我们将会对接 [gayhub 公共 api](https://developer.github.com/v3/repos/) 获取项目信息, 有兴趣的小伙伴可以提前预习一哈, 大家玩儿的开心
![2018-11-14-21-35-33](https://user-gold-cdn.xitu.io/2018/11/14/167126ff280bca6f?w=560&h=552&f=png&s=451422)