Vscode setting.json个人设置(包含保存格式化,空格、换行,标点符号自动增删)
插件安装如图:
(某些非下面配置必须)
简略版
{
"editor.fontSize": 18,
"editor.formatOnSave": true,
"editor.formatOnType": true, //开启自动格式化
"window.zoomLevel": 0,
"eslint.validate": [
"javascript",
"javascriptreact",
"html",
"vue"
],
"editor.codeActionsOnSave": {
"source.fixAll.eslint": true // #每次保存的时候将代码按eslint格式进行修复
},
"editor.wordWrap": "on",
"editor.wordWrapColumn": 800,
"[markdown]": {
"editor.wordWrap": "on",
"editor.quickSuggestions": false
},
"vetur.format.defaultFormatter.js": "vscode-typescript",
"vetur.format.defaultFormatter.html": "js-beautify-html", // 使用beautify对html进行格式化
"vetur.format.defaultFormatterOptions": {
"prettier": {
"semi": false, // 取消自动加分号
"singleQuote": true,
"trailingComma": "none", // 末尾逗号的去除
"wrapAttributes": false,
"sortAttributes": false
},
"js-beautify-html": {
"wrap_attributes": "auto" // html attributes不换行
},
},
"javascript.format.insertSpaceAfterFunctionKeywordForAnonymousFunctions": false, // #取消函数(名)和后面的括号之间空格
"files.autoSave": "off",
"editor.detectIndentation": false,
"editor.tabSize": 2
}
详细
{
// vscode默认启用了根据文件类型自动设置tabsize的选项
"editor.detectIndentation": false,
// 重新设定tabsize
"editor.tabSize": 2,
// #每次保存的时候自动格式化
"editor.formatOnSave": true,
// #每次保存的时候将代码按eslint格式进行修复,vscode es6语法检测配置
"editor.codeActionsOnSave": {
"source.fixAll.eslint": true
},
// "eslint.autoFixOnSave": true,
"explorer.confirmDragAndDrop": false,
// #让函数(名)和后面的括号之间加个空格
"javascript.format.insertSpaceBeforeFunctionParenthesis": true,
// #这个按用户自身习惯选择
"vetur.format.defaultFormatter.html": "js-beautify-html",
// #让vue中的js按编辑器自带的ts格式进行格式化
"vetur.format.defaultFormatter.js": "vscode-typescript",
// 使能每一种语言默认格式化规则
"[html]": {
"editor.defaultFormatter": "esbenp.prettier-vscode"
},
"[css]": {
"editor.defaultFormatter": "esbenp.prettier-vscode"
},
"[less]": {
"editor.defaultFormatter": "esbenp.prettier-vscode"
},
"[javascript]": {
"editor.defaultFormatter": "esbenp.prettier-vscode"
},
/* prettier的配置 */
// "prettier.printWidth": 100, // 超过最大值换行
"prettier.tabWidth": 2, // 缩进字节数
"prettier.useTabs": false, // false缩进不使用tab,使用空格
"prettier.semi": false, // true句尾添加分号
"prettier.singleQuote": true, // true使用单引号代替双引号
"prettier.proseWrap": "preserve", // 默认值。因为使用了一些折行敏感型的渲染器(如GitHub comment)而按照markdown文本样式进行折行
"prettier.arrowParens": "avoid", // (x) => {} 箭头函数参数只有一个时是否要有小括号。avoid:省略括号
"prettier.bracketSpacing": true, // 在对象,数组括号与文字之间加空格 "{ foo: bar }"
"prettier.disableLanguages": [
"vue"
], // 不格式化vue文件,vue文件的格式化单独设置
"prettier.endOfLine": "auto", // 结尾是 \n \r \n\r auto
"prettier.eslintIntegration": false, //不让prettier使用eslint的代码格式进行校验
"prettier.htmlWhitespaceSensitivity": "ignore",
"prettier.ignorePath": ".prettierignore", // 不使用prettier格式化的文件填写在项目的.prettierignore文件中
"prettier.jsxBracketSameLine": false, // 在jsx中把'>' 是否单独放一行
"prettier.jsxSingleQuote": false, // 在jsx中使用单引号代替双引号
"prettier.parser": "babylon", // 格式化的解析器,默认是babylon
"prettier.requireConfig": false, // Require a 'prettierconfig' to format prettier
"prettier.stylelintIntegration": false, //不让prettier使用stylelint的代码格式进行校验
"prettier.trailingComma": "es5", // 在对象或数组最后一个元素后面是否加逗号(在ES5中加尾逗号)
"prettier.tslintIntegration": false, // 不让prettier使用tslint的代码格式进行校验
// ===========以下4个是控制保存时自动格式化的,并且以4格缩进================
"editor.tabCompletion": "on",
// ===========以下是根据自己需求配置的============================
"editor.suggest.snippetsPreventQuickSuggestions": true, //自动补全的
"explorer.confirmDelete": true, // 自动补全
"[json]": {},
"workbench.sideBar.location": "left",
"editor.wordWrap": "on", // 控制折行方式。可以选择: - “off” (禁用折行), - “on” (视区折行), - “wordWrapColumn”(在“editor.wordWrapColumn”处折行)或 - “bounded”(在视区与“editor.wordWrapColumn”两者的较小者处折行)。
"editor.fontSize": 18,
// 两个选择器中是否换行
"editor.formatOnType": true,
"editor.parameterHints": true,
"editor.quickSuggestions": {
"other": true,
"comments": true,
"strings": true
},
"git.confirmSync": true, // *** 这个是提示空格的点点
"typescript.format.insertSpaceAfterSemicolonInForStatements": false,
"search.exclude": {
"**/node_modules": true,
"**/bower_components": true,
"**/dist": true
},
"emmet.includeLanguages": {
"vue-html": "html",
"vue": "html",
"javascript": "javascriptreact",
"wxml": "html"
},
"editor.fontFamily": "'Droid Sans Mono', 'Courier New', monospace, 'Droid Sans Fallback'", // 这个是控制字体样式的
"auto-close-tag.activationOnLanguage": [
"xml",
"php",
"blade",
"ejs",
"jinja",
"javascript",
"javascriptreact",
"typescript",
"typescriptreact",
"plaintext",
"markdown",
"vue",
"liquid",
"erb",
"lang-cfml",
"cfml",
"HTML (Eex)"
],
"eslint.options": {
"extensions": [
".js",
".vue"
]
},
"editor.mouseWheelZoom": true,
"editor.suggestSelection": "first",
"vsintellicode.modify.editor.suggestSelection": "automaticallyOverrodeDefaultValue",
"files.exclude": {
"**/.classpath": true,
"**/.project": true,
"**/.settings": true,
"**/.factorypath": true
},
"launch": {},
"workbench.editorAssociations": [],
"workbench.colorTheme": "Default Dark+",
"terminal.integrated.env.osx": {},
"files.autoSave": "afterDelay",
"vetur.format.defaultFormatterOptions": {
"js-beautify-html": {
// 解决频繁换行问题
"wrap_attributes": "auto"
},
"prettyhtml": {
"printWidth": 100,
"singleQuote": false,
"wrapAttributes": false,
"sortAttributes": false
}
},
}