基于Visual Studio Code搭建Vue开发环境
安装node.js最新版
这里安装的是8.11.4
版
data:image/s3,"s3://crabby-images/540ef/540ef5c13cd636068bfd3afed1122b426939fb1f" alt=""
更新npm至最新版
安装node.js后, npm默认版本为: 6.1.0
data:image/s3,"s3://crabby-images/cfe6f/cfe6f80699f03a368d8d7289764e319f89ed9c7e" alt=""
使用
npm install npm -g
更新npm至最新版data:image/s3,"s3://crabby-images/491f0/491f0bb032e4c7bc8a250a05c142f6efbeda4144" alt=""
安装vs code
安装过程就忽略了.
安装@vue/cli
> npm install -g @vue/cli
data:image/s3,"s3://crabby-images/a31ed/a31eddf6e35fab4c4854bfa844ad2a0c349303d3" alt=""
创建一个vue-demo-project工程
创建过程中默认配置(开箱即用)
data:image/s3,"s3://crabby-images/15289/15289a4e2128df22f052423fe1558467af92f687" alt=""
data:image/s3,"s3://crabby-images/08c92/08c924c61a8ddb5a7a2bf5a0f6ae5a6f321f5089" alt=""
打开工程
data:image/s3,"s3://crabby-images/e454f/e454f16b81ec6206c95c92abe198876a43390e47" alt=""
默认情况下, VS code是使用英文的, 有需要的话, 大家也可自行修改为中文:
- 按下ctrl+p, 输入:
> Config
, 选择: “Configure Display Language"
image.png
-
将原先的:
image.png
修改为:
image.png
修改并保存后, 会提示安装语言包, 安装即可:
打开一个.vue
的文件时, 会提示推荐安装vetur
插件, 当然选择安装了。安装成功后,会提示重启vscode
data:image/s3,"s3://crabby-images/ba72e/ba72efb930f6a1afb9d4dcde2392fc16e8ba7afb" alt=""
Vetur支持.vue文件的语法高亮显示,除了支持template模板以外,还支持大多数主流的前端开发脚本和插件,比如Sass和TypeScript等等
eslint
此时打开一个vue文件并编辑, 保存时并不会自动进行格式化, 这里还需要安装一些依赖和一些配置。
data:image/s3,"s3://crabby-images/ba629/ba629aca119c38a3e1d33ad58fa775d3f8b46cb9" alt=""
首先需要安装eslint
> npm install -g eslint
data:image/s3,"s3://crabby-images/ff96f/ff96ff34b8a010a9813febd586210fa9fff73be1" alt=""
安装vscode 插件eslint
安装好vscode插件后, 执行vscode如下命令:
data:image/s3,"s3://crabby-images/3e9c0/3e9c0073641db0b2a72776a8aacc81d804f0125a" alt=""
此时会在终端执行以下命令, 并按提示进行选择:
d:\Project\vue-demo-project>node_modules.bin\eslint.cmd --init
? How would you like to configure ESLint? Answer questions about your style
? Which version of ECMAScript do you use? ES2015
? Are you using ES6 modules? Yes
? Where will your code run? Browser
? Do you use CommonJS? Yes
? Do you use JSX? Yes
? Do you use React? Yes
? What style of indentation do you use? Tabs
? What quotes do you use for strings? Double
? What line endings do you use? Windows
? Do you require semicolons? No
? What format do you want your config file to be in? JSON
The config that you've selected requires the following dependencies:
eslint-plugin-react@latest
Successfully created .eslintrc.json file in d:\Project\vue-demo-project
d:\Project\vue-demo-project>
完成以上动作后, 会在当前工程目录下生成一个 .eslintrc.json文件
vs code中配置eslint保存时自动格式化
具体配置如下:
{
"files.autoSave": "off",
"files.autoSaveDelay": 1000,
"team.showWelcomeMessage": false,
"emmet.syntaxProfiles": {
"vue-html": "html",
"vue": "html"
},
"eslint.autoFixOnSave": true,
"eslint.validate": [
"javascript",{
"language": "vue",
"autoFix": true
},
"javascriptreact",
"html",
"vue"
],
"eslint.options": {
"plugins": ["html"]
},
//为了符合eslint的两个空格间隔原则
"editor.tabSize": 2,
"eslint.enable": true
}
eslint相关问题
1. eslint未生效
查看并检查下eslint server是否启动或报错
data:image/s3,"s3://crabby-images/6dde3/6dde314cae596f8130d562e2a5c3d20c21e94b3f" alt=""
若有出错, 一般会给出提示, 按提示处理就好了。
2. 报错: Expected linebreaks to be 'CRLF' but found 'LF'. (linebreak-style)
有时会出现报错信息: Expected linebreaks to be 'CRLF' but found 'LF'. (linebreak-style)
不同的操作系统下,甚至是不同编辑器,不同工具处理过的文件可能都会导致换行符的改变。
如果实在找不出原因, 或者无法解决, 可以先关闭此项检测。
// 统一换行符,"\n" unix(for LF) and "\r\n" for windows(CRLF),默认unix
// off或0: 禁用规则
'linebreak-style': 'off'
最终的.eslintrc.json文件内容如下
{
"env": {
"browser": true,
"commonjs": true,
"es6": true
},
"extends": "eslint:recommended",
"parserOptions": {
"ecmaFeatures": {
"jsx": true
},
"ecmaVersion": 2018,
"sourceType": "module"
},
"plugins": [
"react"
],
"rules": {
"indent": [
"error",
"tab"
],
"linebreak-style": "off",
"quotes": [
"error",
"double"
],
"semi": [
"error",
"never"
]
}
}