vue 之 ESLint学习(格式化操作)
在vscode 的右下角 有一个eslint 可以控制
在vscode保存时对代码格式化存在的因素:
第一个因素:存在vscode插件的原因
第二个因素:
查看代码是否符合standar规范: https://standardjs.com/rules-zhcn.html
查看具体细则:https://cn.eslint.org/docs/rules/
ESLint:目标是提供一个插件化的javascript代码检测工具
步骤:
npm init -y 生成package.json
yarn add -D eslint 安装后通过npx 来调用
ESLint出现问题有以下情况:
第一个:setting.json文件内容
第二个:vscode 右下角: 选择的文件编译:vue,而不是html
第三个:vscode右下角:不要禁用eslint检测
配置文件:
setting.json
注意项:
这里面有很多重复的设置,例如保存就有好几种,只需要一种即可,否则就会产生冲突,所以其他也一样
{ // 这个是编辑器设置了自动保存,修改后不会触发eslint自动修复 // "files.autoSave": "afterDelay", // "[html]": { // "editor.defaultFormatter": "vscode.html-language-features" // }, "[css]": { "editor.defaultFormatter": "michelemelluso.code-beautifier" }, //eslint 代码自动检查相关配置 "eslint.enable": true, "eslint.options": { "extensions": [ ".js", ".vue" ] }, // "prettier.eslintIntegration":true, // 制表符符号eslint tab 两个空格 "editor.tabSize": 2, // 字体15大小 "editor.fontSize": 15, //单引号替代双引号 "prettier.singleQuote": true, // 去掉代码结尾的分号 "prettier.semi": true, "window.zoomLevel": 0, "workbench.iconTheme": "vscode-icons", // 保存代码 不自动格式化(会出现冒号等符号的保存,最好禁止false) // "editor.formatOnSave": false, //用来进行保存时自动格式化,但是只支持js(可要可不要) 重点 // "eslint.autoFixOnSave": false, // "explorer.confirmDelete": false, // 当保存的时候,eslint自动帮我们修复错误 重点 推荐将vscode上的所有代码格式化插件全部禁止 "editor.codeActionsOnSave": { "source.fixAll": true }, "[vue]": { "editor.defaultFormatter": "octref.vetur" // "editor.defaultFormatter": "HookyQR.beautify" }, "path-intellisense.mappings": { "@": "${workspaceRoot}/src" }, "[javascript]": { "editor.defaultFormatter": "esbenp.prettier-vscode" }, "workbench.colorTheme": "Atom One Dark", "vetur.format.defaultFormatter.html": "js-beautify-html", //#这个按用户自身习惯选择 "vetur.format.defaultFormatter.js": "vscode-typescript", //#让vue中的js按编辑器自带的ts格式进行格式化 "vetur.format.defaultFormatterOptions": { "js-beautify-html": { "wrap_attributes": "force-aligned" //#vue组件中html代码格式化样式 } } }
还可以进行配置
.eslintrc.js
module.exports = { root: true, parserOptions: { parser: 'babel-eslint', sourceType: 'module' }, env: { browser: true, node: true, es6: true, }, extends: ['plugin:vue/recommended', 'eslint:recommended'], // add your custom rules here //it is base on https://github.com/vuejs/eslint-config-vue rules: { "vue/max-attributes-per-line": [2, { "singleline": 10, "multiline": { "max": 1, "allowFirstLine": false } }], "vue/singleline-html-element-content-newline": "off", "vue/multiline-html-element-content-newline":"off", "vue/name-property-casing": ["error", "PascalCase"], "vue/no-v-html": "off", 'accessor-pairs': 2, 'arrow-spacing': [2, { 'before': true, 'after': true }], 'block-spacing': [2, 'always'], 'brace-style': [2, '1tbs', { 'allowSingleLine': true }], 'camelcase': [0, { 'properties': 'always' }], 'comma-dangle': [2, 'never'], 'comma-spacing': [2, { 'before': false, 'after': true }], 'comma-style': [2, 'last'], 'constructor-super': 2, 'curly': [2, 'multi-line'], 'dot-location': [2, 'property'], 'eol-last': 2, 'eqeqeq': ["error", "always", {"null": "ignore"}], 'generator-star-spacing': [2, { 'before': true, 'after': true }], 'handle-callback-err': [2, '^(err|error)$'], 'indent': [2, 2, { 'SwitchCase': 1 }], 'jsx-quotes': [2, 'prefer-single'], 'key-spacing': [2, { 'beforeColon': false, 'afterColon': true }], 'keyword-spacing': [2, { 'before': true, 'after': true }], 'new-cap': [2, { 'newIsCap': true, 'capIsNew': false }], 'new-parens': 2, 'no-array-constructor': 2, 'no-caller': 2, 'no-console': 'off', 'no-class-assign': 2, 'no-cond-assign': 2, 'no-const-assign': 2, 'no-control-regex': 0, 'no-delete-var': 2, 'no-dupe-args': 2, 'no-dupe-class-members': 2, 'no-dupe-keys': 2, 'no-duplicate-case': 2, 'no-empty-character-class': 2, 'no-empty-pattern': 2, 'no-eval': 2, 'no-ex-assign': 2, 'no-extend-native': 2, 'no-extra-bind': 2, 'no-extra-boolean-cast': 2, 'no-extra-parens': [2, 'functions'], 'no-fallthrough': 2, 'no-floating-decimal': 2, 'no-func-assign': 2, 'no-implied-eval': 2, 'no-inner-declarations': [2, 'functions'], 'no-invalid-regexp': 2, 'no-irregular-whitespace': 2, 'no-iterator': 2, 'no-label-var': 2, 'no-labels': [2, { 'allowLoop': false, 'allowSwitch': false }], 'no-lone-blocks': 2, 'no-mixed-spaces-and-tabs': 2, 'no-multi-spaces': 2, 'no-multi-str': 2, 'no-multiple-empty-lines': [2, { 'max': 1 }], 'no-native-reassign': 2, 'no-negated-in-lhs': 2, 'no-new-object': 2, 'no-new-require': 2, 'no-new-symbol': 2, 'no-new-wrappers': 2, 'no-obj-calls': 2, 'no-octal': 2, 'no-octal-escape': 2, 'no-path-concat': 2, 'no-proto': 2, 'no-redeclare': 2, 'no-regex-spaces': 2, 'no-return-assign': [2, 'except-parens'], 'no-self-assign': 2, 'no-self-compare': 2, 'no-sequences': 2, 'no-shadow-restricted-names': 2, 'no-spaced-func': 2, 'no-sparse-arrays': 2, 'no-this-before-super': 2, 'no-throw-literal': 2, 'no-trailing-spaces': 2, 'no-undef': 2, 'no-undef-init': 2, 'no-unexpected-multiline': 2, 'no-unmodified-loop-condition': 2, 'no-unneeded-ternary': [2, { 'defaultAssignment': false }], 'no-unreachable': 2, 'no-unsafe-finally': 2, 'no-unused-vars': [2, { 'vars': 'all', 'args': 'none' }], 'no-useless-call': 2, 'no-useless-computed-key': 2, 'no-useless-constructor': 2, 'no-useless-escape': 0, 'no-whitespace-before-property': 2, 'no-with': 2, 'one-var': [2, { 'initialized': 'never' }], 'operator-linebreak': [2, 'after', { 'overrides': { '?': 'before', ':': 'before' } }], 'padded-blocks': [2, 'never'], 'quotes': [2, 'single', { 'avoidEscape': true, 'allowTemplateLiterals': true }], 'semi': [2, 'never'], 'semi-spacing': [2, { 'before': false, 'after': true }], 'space-before-blocks': [2, 'always'], 'space-before-function-paren': [2, 'never'], 'space-in-parens': [2, 'never'], 'space-infix-ops': 2, 'space-unary-ops': [2, { 'words': true, 'nonwords': false }], 'spaced-comment': [2, 'always', { 'markers': ['global', 'globals', 'eslint', 'eslint-disable', '*package', '!', ','] }], 'template-curly-spacing': [2, 'never'], 'use-isnan': 2, 'valid-typeof': 2, 'wrap-iife': [2, 'any'], 'yield-star-spacing': [2, 'both'], 'yoda': [2, 'never'], 'prefer-const': 2, 'no-debugger': process.env.NODE_ENV === 'production' ? 2 : 0, 'object-curly-spacing': [2, 'always', { objectsInObjects: false }], 'array-bracket-spacing': [2, 'never'] } }