vscode常用插件及用户配置

一.常用插件及功能描述

1.Html CSS Support

css代码自动完成

2.Html SCSS Support

scss代码自动完成

3.html snippets 

html代码自动提示,能够自动生成代码片段

4.Auto rename tag

在HTML, XML文件中修改标签时,直接在前标签名上修改,插件会自动修改后标签名

5.Auto close tag

在HTML, XML文件中添加前标签名后自动添加后标签名

6.JavaScript (ES6) code snippets

ES6代码提示

7.Beautify css, sass and less

选中代码片段,点击右键可格式化文档,美化css代码格式

8.eslint

代码检查工具

9.jQuery Snippets

jquery代码提示

10.Path Intellisense 

文件路径自动补全

11.Bracket Pair Colorizer 

不同层级的括号显示不同的颜色,方便查找括号作用域

12.JS-CSS-HTML Formatter 

JS、CSS、HTML代码格式化插件

13.Path Autocomplete

引入文件时路径提示

14.vetur

vue代码提示,代码格式化

15.Vue 2 Snippets 

vue代码片段自动完成

16.VueTypeScript Snippets

vue ts语法提示

17.px-to-rem

像素与rem相互转换,默认快捷键alt + z

18.vscode-fileheader

插入文件头注释,并能自动更新文件修改时间,默认快捷键为 ctrl + alt + i,如果有冲突,到 文件 - 首选项 - 键盘快捷方式中进行修改

19.vscode-icons

为文件管理器增加文件类型图标

20.Project Manager

在多个项目之前快速切换的工具

21.View In Browser

右键文件使用浏览器打开

二.用户配置

在【文件】——【首选项】——【设置】中根据自己的习惯及项目的代码风格自定义一些规则

{

    // 调整窗口的缩放级别。原始大小是 0,每次递增(例如 1)或递减(例如 -1)表示放大或缩小 20%。也可以输入小数以便以更精细的粒度调整缩放级别。

    "window.zoomLevel": 1,

    // 指定工作台中使用的颜色主题。

    "workbench.colorTheme": "Monokai",

    // 指定在工作台中使用的图标主题

    "workbench.iconTheme": "vscode-icons",

    // 窗口失去焦点自动保存

    "files.autoSave": "off",

    // 如果设置为 "true",将不再显示扩展建议的通知。

    "extensions.ignoreRecommendations": true,

    // 如果设置成 true,关于新的版本消息将不再显示

    "vsicons.dontShowNewVersionMessage": true,

    // 控制是否将打开的编辑器显示为预览。

    "workbench.editor.enablePreview": false,

    //代码缩进风格4个字符

    "editor.tabSize": 4,

    // 控制编辑器是否应在键入后自动设置行的格式

    "editor.formatOnType": false,

    // 保存时取消自动格式化

    "editor.formatOnSave": false,

    // 编辑粘贴取消自动格式化

    "editor.formatOnPaste": false,

    // 控制编辑器中呈现空白字符的方式为“边界”,不会在单词之间呈现单空格。

    "editor.renderWhitespace": "boundary",

    // 控制光标动画样式

    "editor.cursorBlinking": "smooth",

    //设置Eslint需要验证的语言

    "eslint.validate": [

        "javascript",

        "javascriptreact",

        "html",

        "vue",

        {

            "language": "vue",

            "autoFix": true

        }

    ],

    // 终端在 Windows 使用的 shell 路径。

    "terminal.integrated.shell.windows": "C:\\Program Files\\Git\\bin\\bash.exe",

    // 用鼠标添加多个光标时使用的修改键。

    "editor.multiCursorModifier": "ctrlCmd",

    // 控制是否将代码段与其他建议一起显示以及它们的排序方式。

    "editor.snippetSuggestions": "top",

    // 配置语言的文件关联

    "files.associations": {

        "*.vue": "vue"

    },

    //打开或关闭自动保存

    "eslint.autoFixOnSave": false,

    "eslint.options": {

        "extensions": [

            ".js",

            ".vue"

        ]

    },

    //配置 glob 模式以在搜索中排除文件和文件夹。

    "search.exclude": {

        "**/node_modules": true,

        "**/bower_components": true,

        "**/dist": true

    },

    // 为指定的语法定义配置文件或使用带有特定规则的配置文件。

    "emmet.syntaxProfiles": {

        "javascript": "jsx",

        "vue": "html",

        "vue-html": "html"

    },

    //px转rem比例

    "px-to-rem.px-per-rem": 67.5,

    //默认格式化js插件

    "vetur.format.defaultFormatter.js": "vscode-typescript",

    //默认格式化html插件

    "vetur.format.defaultFormatter.html": "js-beautify-html",

    //vetur格式化时初始化script缩进

    "vetur.format.scriptInitialIndent": true,

    //vetur格式化时初始化style缩进

    "vetur.format.styleInitialIndent": true,

    //vetur格式化时初始化style缩进

    "vetur.format.options.tabSize": 4,

    //vetur格式化时初始化html配置

    "vetur.format.defaultFormatterOptions": {

        "js-beautify-html": {

            //设置html属性是否换行

            "wrap_attributes": "auto"

        },

        "prettyhtml": {

            "printWidth": 100,

            "singleQuote": false,

            "wrapAttributes": false,

            "sortAttributes": false

        }

    },

    //每列显示内容长多,超出时控制编辑器列的换行。

    "editor.wordWrap": "wordWrapColumn",

    "editor.wordWrapColumn": 150,

    //创建人,修改人

    "fileheader.Author": "klierbyck",

    "fileheader.LastModifiedBy": "klierbyck",

    // 在函数参数括号前定义空格处理。需要 TypeScript >= 2.1.5。

    "typescript.format.insertSpaceBeforeFunctionParenthesis": true,

    // 在函数参数括号前定义空格处理。需要 TypeScript >= 2.1.5。

    "javascript.format.insertSpaceBeforeFunctionParenthesis": true,

}

三.ESLint语法检查规则配置

在配置文件中设置规则等级有三种:

1."off" 或者 0:关闭规则。

2."warn" 或者 1:打开规则,并且作为一个警告。

3."error" 或者 2:打开规则,并且作为一个错误。

module.exports = {

    root: true,

    parser: 'babel-eslint',

    parserOptions: {

        sourceType: 'module'

    },

    env: {

        browser: true

    },

    // https://github.com/standard/standard/blob/master/docs/RULES-en.md

    extends: 'standard',

    // required to lint *.vue files

    plugins: ['html'],

    // 规则参考: https://www.cnblogs.com/my93/p/5681879.html

    // add your custom rules here

    rules: {

        "no-alert": 0, //禁止使用alert confirm prompt

        "no-array-constructor": 2, //禁止使用数组构造器

        "no-bitwise": 0, //禁止使用按位运算符

        "no-caller": 1, //禁止使用arguments.caller或arguments.callee

        "no-catch-shadow": 2, //禁止catch子句参数与外部作用域变量同名

        "no-class-assign": 2, //禁止给类赋值

        "no-cond-assign": 2, //禁止在条件表达式中使用赋值语句

        "no-console": 2, //禁止使用console

        "no-const-assign": 2, //禁止修改const声明的变量

        "no-constant-condition": 2, //禁止在条件中使用常量表达式 if(true) if(1)

        "no-continue": 0, //禁止使用continue

        "no-control-regex": 2, //禁止在正则表达式中使用控制字符

        "no-debugger": 2, //禁止使用debugger

        "no-delete-var": 2, //不能对var声明的变量使用delete操作符

        "no-div-regex": 1, //不能使用看起来像除法的正则表达式/=foo/

        "no-dupe-keys": 2, //在创建对象字面量时不允许键重复 {a:1,a:1}

        "no-dupe-args": 2, //函数参数不能重复

        "no-duplicate-case": 2, //switch中的case标签不能重复

        "no-else-return": 2, //如果if语句里面有return,后面不能跟else语句

        "no-empty": 2, //块语句中的内容不能为空

        "no-empty-character-class": 2, //正则表达式中的[]内容不能为空

        "no-empty-label": 2, //禁止使用空label

        "no-eq-null": 2, //禁止对null使用==或!=运算符

        "no-eval": 1, //禁止使用eval

        "no-ex-assign": 2, //禁止给catch语句中的异常参数赋值

        "no-extend-native": 2, //禁止扩展native对象

        "no-extra-bind": 2, //禁止不必要的函数绑定

        "no-extra-boolean-cast": 2, //禁止不必要的bool转换

        "no-extra-parens": 2, //禁止非必要的括号

        "no-extra-semi": 2, //禁止多余的冒号

        "no-fallthrough": 1, //禁止switch穿透

        "no-floating-decimal": 2, //禁止省略浮点数中的0 .5 3.

        "no-func-assign": 2, //禁止重复的函数声明

        "no-implicit-coercion": 1, //禁止隐式转换

        "no-implied-eval": 2, //禁止使用隐式eval

        "no-inline-comments": 0, //禁止行内备注

        "no-inner-declarations": [2, "functions"], //禁止在块语句中使用声明(变量或函数)

        "no-invalid-regexp": 2, //禁止无效的正则表达式

        "no-invalid-this": 2, //禁止无效的this,只能用在构造器,类,对象字面量

        "no-irregular-whitespace": 2, //不能有不规则的空格

        "no-iterator": 2, //禁止使用__iterator__ 属性

        "no-label-var": 2, //label名不能与var声明的变量名相同

        "no-labels": 2, //禁止标签声明

        "no-lone-blocks": 2, //禁止不必要的嵌套块

        "no-lonely-if": 2, //禁止else语句内只有if语句

        "no-loop-func": 1, //禁止在循环中使用函数(如果没有引用外部变量不形成闭包就可以)

        "no-mixed-requires": [0, false], //声明时不能混用声明类型

        "no-mixed-spaces-and-tabs": [2, false], //禁止混用tab和空格

        "linebreak-style": [0, "windows"], //换行风格

        "no-multi-spaces": 1, //不能用多余的空格

        "no-multi-str": 2, //字符串不能用\换行

        "no-multiple-empty-lines": [1, { "max": 2 }], //空行最多不能超过2行

        "no-native-reassign": 2, //不能重写native对象

        "no-negated-in-lhs": 2, //in 操作符的左边不能有!

        "no-nested-ternary": 0, //禁止使用嵌套的三目运算

        "no-new": 1, //禁止在使用new构造一个实例后不赋值

        "no-new-func": 1, //禁止使用new Function

        "no-new-object": 2, //禁止使用new Object()

        "no-new-require": 2, //禁止使用new require

        "no-new-wrappers": 2, //禁止使用new创建包装实例,new String new Boolean new Number

        "no-obj-calls": 2, //不能调用内置的全局对象,比如Math() JSON()

        "no-octal": 2, //禁止使用八进制数字

        "no-octal-escape": 2, //禁止使用八进制转义序列

        "no-param-reassign": 2, //禁止给参数重新赋值

        "no-path-concat": 0, //node中不能使用__dirname或__filename做路径拼接

        "no-plusplus": 0, //禁止使用++,--

        "no-process-env": 0, //禁止使用process.env

        "no-process-exit": 0, //禁止使用process.exit()

        "no-proto": 2, //禁止使用__proto__属性

        "no-redeclare": 2, //禁止重复声明变量

        "no-regex-spaces": 2, //禁止在正则表达式字面量中使用多个空格 /foo bar/

        "no-restricted-modules": 0, //如果禁用了指定模块,使用就会报错

        "no-return-assign": 1, //return 语句中不能有赋值表达式

        "no-script-url": 0, //禁止使用javascript:void(0)

        "no-self-compare": 2, //不能比较自身

        "no-sequences": 0, //禁止使用逗号运算符

        "no-shadow": 2, //外部作用域中的变量不能与它所包含的作用域中的变量或参数同名

        "no-shadow-restricted-names": 2, //严格模式中规定的限制标识符不能作为声明时的变量名使用

        "no-spaced-func": 2, //函数调用时 函数名与()之间不能有空格

        "no-sparse-arrays": 2, //禁止稀疏数组, [1,,2]

        "no-sync": 0, //nodejs 禁止同步方法

        "no-ternary": 0, //禁止使用三目运算符

        "no-trailing-spaces": 1, //一行结束后面不要有空格

        "no-this-before-super": 0, //在调用super()之前不能使用this或super

        "no-throw-literal": 2, //禁止抛出字面量错误 throw "error";

        "no-undef": 1, //不能有未定义的变量

        "no-undef-init": 2, //变量初始化时不能直接给它赋值为undefined

        "no-undefined": 2, //不能使用undefined

        "no-unexpected-multiline": 2, //避免多行表达式

        "no-underscore-dangle": 1, //标识符不能以_开头或结尾

        "no-unneeded-ternary": 2, //禁止不必要的嵌套 var isYes = answer === 1 ? true : false;

        "no-unreachable": 2, //不能有无法执行的代码

        "no-unused-expressions": 2, //禁止无用的表达式

        "no-unused-vars": [2, { "vars": "all", "args": "after-used" }], //不能有声明后未被使用的变量或参数

        "no-use-before-define": 2, //未定义前不能使用

        "no-useless-call": 2, //禁止不必要的call和apply

        "no-void": 2, //禁用void操作符

        "no-var": 0, //禁用var,用let和const代替

        "no-warning-comments": [1, { "terms": ["todo", "fixme", "xxx"], "location": "start" }], //不能有警告备注

        "no-with": 2, //禁用with

        "array-bracket-spacing": [2, "never"], //是否允许非空数组里面有多余的空格

        "arrow-parens": 0, //箭头函数用小括号括起来

        "arrow-spacing": 0, //=>的前/后括号

        "accessor-pairs": 0, //在对象中使用getter/setter

        "block-scoped-var": 0, //块语句中使用var

        "brace-style": [1, "1tbs"], //大括号风格

        "callback-return": 1, //避免多次调用回调什么的

        "camelcase": 2, //强制驼峰法命名

        "comma-dangle": [2, "never"], //对象字面量项尾不能有逗号

        "comma-spacing": 0, //逗号前后的空格

        "comma-style": [2, "last"], //逗号风格,换行时在行首还是行尾

        "complexity": [0, 11], //循环复杂度

        "computed-property-spacing": [0, "never"], //是否允许计算后的键名什么的

        "consistent-return": 0, //return 后面是否允许省略

        "consistent-this": [2, "that"], //this别名

        "constructor-super": 0, //非派生类不能调用super,派生类必须调用super

        "curly": [2, "all"], //必须使用 if(){} 中的{}

        "default-case": 2, //switch语句最后必须有default

        "dot-location": 0, //对象访问符的位置,换行的时候在行首还是行尾

        "dot-notation": [0, { "allowKeywords": true }], //避免不必要的方括号

        "eol-last": 0, //文件以单一的换行符结束

        "eqeqeq": 2, //必须使用全等

        "func-names": 0, //函数表达式必须有名字

        "func-style": [0, "declaration"], //函数风格,规定只能使用函数声明/函数表达式

        "generator-star-spacing": 0, //生成器函数*的前后空格

        "guard-for-in": 0, //for in循环要用if语句过滤

        "handle-callback-err": 0, //nodejs 处理错误

        "id-length": 0, //变量名长度

        "indent": [2, 4], //缩进风格

        "init-declarations": 0, //声明时必须赋初值

        "key-spacing": [0, { "beforeColon": false, "afterColon": true }], //对象字面量中冒号的前后空格

        "lines-around-comment": 0, //行前/行后备注

        "max-depth": [0, 4], //嵌套块深度

        "max-len": [0, 80, 4], //字符串最大长度

        "max-nested-callbacks": [0, 2], //回调嵌套深度

        "max-params": [0, 3], //函数最多只能有3个参数

        "max-statements": [0, 10], //函数内最多有几个声明

        "new-cap": 2, //函数名首行大写必须使用new方式调用,首行小写必须用不带new方式调用

        "new-parens": 2, //new时必须加小括号

        "newline-after-var": 2, //变量声明后是否需要空一行

        "object-curly-spacing": [0, "never"], //大括号内是否允许不必要的空格

        "object-shorthand": 0, //强制对象字面量缩写语法

        "one-var": 1, //连续声明

        "operator-assignment": [0, "always"], //赋值运算符 += -=什么的

        "operator-linebreak": [2, "after"], //换行时运算符在行尾还是行首

        "padded-blocks": 0, //块语句内行首行尾是否要空行

        "prefer-const": 0, //首选const

        "prefer-spread": 0, //首选展开运算

        "prefer-reflect": 0, //首选Reflect的方法

        "quotes": [1, "single"], //引号类型 `` "" ''

        "quote-props": [2, "always"], //对象字面量中的属性名是否强制双引号

        "radix": 2, //parseInt必须指定第二个参数

        "id-match": 0, //命名检测

        "require-yield": 0, //生成器函数必须有yield

        "semi": [2, "always"], //语句强制分号结尾

        "semi-spacing": [0, { "before": false, "after": true }], //分号前后空格

        "sort-vars": 0, //变量声明时排序

        "space-after-keywords": [0, "always"], //关键字后面是否要空一格

        "space-before-blocks": [0, "always"], //不以新行开始的块{前面要不要有空格

        "space-before-function-paren": [0, "always"], //函数定义时括号前面要不要有空格

        "space-in-parens": [0, "never"], //小括号里面要不要有空格

        "space-infix-ops": 0, //中缀操作符周围要不要有空格

        "space-return-throw-case": 2, //return throw case后面要不要加空格

        "space-unary-ops": [0, { "words": true, "nonwords": false }], //一元运算符的前/后要不要加空格

        "spaced-comment": 0, //注释风格要不要有空格什么的

        "strict": 2, //使用严格模式

        "use-isnan": 2, //禁止比较时使用NaN,只能用isNaN()

        "valid-jsdoc": 0, //jsdoc规则

        "valid-typeof": 2, //必须使用合法的typeof的值

        "vars-on-top": 2, //var必须放在作用域顶部

        "wrap-iife": [2, "inside"], //立即执行函数表达式的小括号风格

        "wrap-regex": 0, //正则表达式字面量用小括号包起来

        "yoda": [2, "never"] //禁止尤达条件

    }

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容