Home Development Tools VSCode How vscode configures eslint+prettier to format Vue code

How vscode configures eslint+prettier to format Vue code

May 25, 2021 am 10:55 AM
eslint prettier vscode

This article will introduce to you vscode eslint prettier method of formatting Vue code. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to everyone.

How vscode configures eslint+prettier to format Vue code

Project background: vue-cli

First install these three plug-ins, Then configure it as needed according to the configuration list

  • ESlint: JavaScript code detection tool, you can configure to format js every time you save, but only Formatting a little bit, you have to hold Ctrl S several times in succession before formatting is complete, experience it by yourself~~

  • vetur: You can format html, standard css (the kind with semicolons and braces), standard js (the kind with semicolons and double quotes), vue files,
    But! The formatted standard js file does not comply with the ESlint specification and will add double quotes, semicolons, etc. for you,

  • Prettier - Code formatter: Only focus on formatting , does not have the ability to check syntax with eslint, but only cares about formatted files (maximum length, mixed tags and spaces, reference styles, etc.), including JavaScript · Flow · TypeScript · CSS · SCSS · Less · JSX · Vue · GraphQL · JSON · Markdown

##[Recommended learning: "

vscode tutorial", "vue.js tutorial"]

vscode json configuration item

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

{

  // git路径

  "git.path": "D:/tool/Git/cmd/git.exe",

  "git.confirmSync": false,

  //.vue文件template格式化支持,并使用js-beautify-html插件

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

  "vetur.format.defaultFormatterOptions": {

    // 对属性进行换行。

    // - auto: 仅在超出行长度时才对属性进行换行。

    // - force: 对除第一个属性外的其他每个属性进行换行。

    // - force-aligned: 对除第一个属性外的其他每个属性进行换行,并保持对齐。

    // - force-expand-multiline: 对每个属性进行换行。

    // - aligned-multiple: 当超出折行长度时,将属性进行垂直对齐。

    "js-beautify-html": {

      "wrap_line_length": 120,

      "wrap_attributes": "auto",

      "end_with_newline": false

    },

    "prettier": {

      "semi": false, //不使用分号结尾

      "singleQuote": true, //使用单引号

      "eslintIntegration": true  //开启 eslint 支持

    }

  },

  //根据文件后缀名定义vue文件类型

  "files.associations": {

    "*.vue": "vue"

  },

  //保存自动格式化

  "editor.formatOnSave": true,

  //配置 ESLint 检查的文件类型

  "eslint.validate": [

    "javascript",

    "javascriptreact",

    "vue-html",

    {

      "language": "vue",

      "autoFix": true

    },

    {

      "language": "html",

      "aotoFix": true

    }

  ],

  "eslint.run": "onSave",

  //保存时eslint自动修复错误

  "eslint.autoFixOnSave": true,

  "files.autoSave": "afterDelay"

}

Copy after login

.eslinttrs.js configuration

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

178

179

180

181

182

183

184

185

186

187

188

189

190

191

192

193

194

195

196

197

198

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']

  }

}

Copy after login

For more programming-related knowledge, please visit:

Programming Video! !

The above is the detailed content of How vscode configures eslint+prettier to format Vue code. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What computer configuration is required for vscode What computer configuration is required for vscode Apr 15, 2025 pm 09:48 PM

VS Code system requirements: Operating system: Windows 10 and above, macOS 10.12 and above, Linux distribution processor: minimum 1.6 GHz, recommended 2.0 GHz and above memory: minimum 512 MB, recommended 4 GB and above storage space: minimum 250 MB, recommended 1 GB and above other requirements: stable network connection, Xorg/Wayland (Linux)

How to define header files for vscode How to define header files for vscode Apr 15, 2025 pm 09:09 PM

How to define header files using Visual Studio Code? Create a header file and declare symbols in the header file using the .h or .hpp suffix name (such as classes, functions, variables) Compile the program using the #include directive to include the header file in the source file. The header file will be included and the declared symbols are available.

How to solve the problem of vscode Chinese annotations becoming question marks How to solve the problem of vscode Chinese annotations becoming question marks Apr 15, 2025 pm 11:36 PM

How to solve the problem that Chinese comments in Visual Studio Code become question marks: Check the file encoding and make sure it is "UTF-8 without BOM". Change the font to a font that supports Chinese characters, such as "Song Style" or "Microsoft Yahei". Reinstall the font. Enable Unicode support. Upgrade VSCode, restart the computer, and recreate the source file.

Common commands for vscode terminal Common commands for vscode terminal Apr 15, 2025 pm 10:06 PM

Common commands for VS Code terminals include: Clear the terminal screen (clear), list the current directory file (ls), change the current working directory (cd), print the current working directory path (pwd), create a new directory (mkdir), delete empty directory (rmdir), create a new file (touch) delete a file or directory (rm), copy a file or directory (cp), move or rename a file or directory (mv) display file content (cat) view file content and scroll (less) view file content only scroll down (more) display the first few lines of the file (head)

How to use VSCode How to use VSCode Apr 15, 2025 pm 11:21 PM

Visual Studio Code (VSCode) is a cross-platform, open source and free code editor developed by Microsoft. It is known for its lightweight, scalability and support for a wide range of programming languages. To install VSCode, please visit the official website to download and run the installer. When using VSCode, you can create new projects, edit code, debug code, navigate projects, expand VSCode, and manage settings. VSCode is available for Windows, macOS, and Linux, supports multiple programming languages ​​and provides various extensions through Marketplace. Its advantages include lightweight, scalability, extensive language support, rich features and version

vscode Previous Next Shortcut Key vscode Previous Next Shortcut Key Apr 15, 2025 pm 10:51 PM

VS Code One-step/Next step shortcut key usage: One-step (backward): Windows/Linux: Ctrl ←; macOS: Cmd ←Next step (forward): Windows/Linux: Ctrl →; macOS: Cmd →

How to switch Chinese mode with vscode How to switch Chinese mode with vscode Apr 15, 2025 pm 11:39 PM

VS Code To switch Chinese mode: Open the settings interface (Windows/Linux: Ctrl, macOS: Cmd,) Search for "Editor: Language" settings Select "Chinese" in the drop-down menu Save settings and restart VS Code

How to set vscode in Chinese How to set vscode in Chinese Apr 15, 2025 pm 09:27 PM

There are two ways to set up a Chinese language in Visual Studio Code: 1. Install the Chinese language package; 2. Modify the "locale" settings in the configuration file. Make sure Visual Studio Code version is 1.17 or higher.

See all articles