公司最近开发项目使用的是vue-cli 3.0
版本开发,可是对于vue-cli 3.0
版本一直没有研究过如何使用,公司使用配置:pug + ts + stylus + eslint;编辑器使用:vscode,使用起来简直不要太爽。css
默认你已经安装了nodejs
前端
vue-cli 3.0
1.安装:vue
npm install -g @vue/cli
-g
: 全局安装 vue-cli
1.建立vue-app
项目:node
vue create vue-app
2.项目配置:vue-cli
如下是我选择的配置(能够直接按数字键1,2,3,4进行选择)typescript
Babel
:将ES6编译成ES5TypeScript
:JS超集,主要是类型检查Router
和Vuex
,路由和状态管理Linter
/ Formatter
:代码检查工具CSS Pre-processors
:css预编译 (稍后会对这里进行配置)Unit Testing
:单元测试,开发过程当中前端对代码进行自运行测试Use class-style component syntax? (Y/n) y
是否使用Class风格装饰器?
即本来是:home = new Vue()
建立vue实例
使用装饰器后:class home extends Vue{}
npm
Use Babel alongside TypeScript for auto-detected polyfills? (Y/n) y
使用Babel与TypeScript一块儿用于自动检测的填充? yesjson
Use history mode for router? (Requires proper server setup for index fallback in production) (Y/n) y
路由使用历史模式? 这种模式充分利用 history.pushState API 来完成 URL 跳转而无须从新加载页面babel
使用什么css预编译器? 我选择的 stylus
app
tslint
: typescript格式验证工具eslint w...
: 只进行报错提醒; 【选这个】eslint + A...
: 不严谨模式;eslint + S...
: 正常模式;eslint + P...
: 严格模式;
代码检查方式:我选择保存时检查

单元测试工具,这里附上vue单元测试的连接,想了解的小伙伴戳这里 https://vue-test-utils.vuejs.org/zh/
vue-cli 通常来说是将全部的依赖目录放在package.json文件里
Save this as a preset for future projects? (y/N) n
是否在之后的项目中使用以上配置?不
下载依赖的工具:使用 yarn,速度快。
到此为止,安装就完成了,能够等待安装成功。
1.vscode
的eslint
配置,使代码可以在ctrl
+s
的时候自动格式化:
在vue-app
目录县新建文件夹.vscode
文件,再在.vscode
目录下新建settings.json
,文件内容以下:
tips:此配置包含了.vue
文件.styl
文件typescript
的代码缩进
{ "prettier.printWidth": 160, "prettier.tabWidth": 2, "prettier.semi": false, "prettier.singleQuote": true, "prettier.disableLanguages": [], "editor.tabSize": 2, "[vue]": { "editor.formatOnSave": true }, "[typescript]": { "editor.formatOnSave": true, }, "[stylus]": { "editor.formatOnSave": true, }, "stylusSupremacy.insertColons": false, "stylusSupremacy.insertSemicolons": false, "stylusSupremacy.insertBraces": false, "languageStylus.useSeparator": false, }
vscode
在读取到vue-app
项目是,回去查找.vscode
下的settings.json
配置并应用。必须禁用插件:eslint
2.使用pug
yarn add pug pug-plain-loader --dev
yarn
安装 pug
和 pug-plain-loader
;(没有yarn
的自行百度安装--dev
:安装到开发环境App.vue
文件,将文件修改成下面这样既可。<template lang="pug"> #app #nav router-link(to="/") Home router-link(to="/about") About router-view </div> </template>
0.其余一些eslint配置均可以在packge.json
文件中的eslintConfig
下的rules
下配置
1.console.log(1)
报错:
找到packge.json
文件中的eslintConfig
下的rules
:
"no-console": "off"