vscode如何配置eslint+prettier来格式化Vue代码

本篇文章给大家介绍一下vscode+eslint+prettier格式化vue代码的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

vscode如何配置eslint+prettier来格式化Vue代码

项目背景 : vue-cli 

先安装好这三个插件,然后根据配置清单按需配置

ESlint:javascript代码检测工具,可以配置每次保存时格式化js,但每次保存只格式化一点点,你得连续按住Ctrl+S好几次,才格式化好,自行体会~~

立即学习“前端免费学习笔记(深入)”;

vetur:可以格式化html、标准css(有分号 、大括号的那种)、标准js(有分号 、双引号的那种)、vue文件,
但是!格式化的标准js文件不符合ESlint规范,会给你加上双引号、分号等,

代码小浣熊 代码小浣熊

代码小浣熊是基于商汤大语言模型的软件智能研发助手,覆盖软件需求分析、架构设计、代码编写、软件测试等环节

代码小浣熊 51 查看详情 代码小浣熊

Prettier – Code formatter:只关注格式化,并不具有eslint检查语法等能力,只关心格式化文件(最大长度、混合标签和空格、引用样式等),包括JavaScript · Flow · TypeScript · CSS · SCSS · Less · JSX · Vue · GraphQL · JSON · Markdown

【推荐学习:《vscode教程》、《vue.js教程》】

vscode json配置项 

{  // 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"}

.eslinttrs.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']  }}

更多编程相关知识,请访问:编程视频!!

以上就是vscode如何配置eslint+prettier来格式化Vue代码的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/502985.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 21:11:22
下一篇 2025年11月8日 21:12:30

相关推荐

  • VSCode选择范围提供者实现

    Selection Range Provider是VSCode中用于实现层级化代码选择的API,通过注册provideSelectionRanges方法,按光标位置从内到外逐层扩展选择范围,如从变量名扩展至函数体;需结合AST解析构建准确的SelectionRange链式结构以提升选择智能性。 在 …

    2025年12月6日 开发工具
    000
  • VSCode终端美化:功率线字体配置

    首先需安装Powerline字体如Nerd Fonts,再在VSCode设置中将terminal.integrated.fontFamily设为’FiraCode Nerd Font’等支持字体,最后配合oh-my-zsh的powerlevel10k等Shell主题启用完整美…

    2025年12月6日 开发工具
    000
  • VSCode入门:基础配置与插件推荐

    刚用VSCode,别急着装一堆东西。先把基础设好,再按需求加插件,效率高还不卡。核心就三步:界面顺手、主题舒服、功能够用。 设置中文和常用界面 打开软件,左边活动栏有五个图标,点最下面那个“扩展”。搜索“Chinese”,装上官方出的“Chinese (Simplified) Language Pa…

    2025年12月6日 开发工具
    000
  • VSCode性能分析与瓶颈诊断技术

    首先通过资源监控定位异常进程,再利用开发者工具分析性能瓶颈,结合禁用扩展、优化语言服务器配置及项目设置,可有效解决VSCode卡顿问题。 VSCode作为主流的代码编辑器,虽然轻量高效,但在处理大型项目或配置复杂扩展时可能出现卡顿、响应延迟等问题。要解决这些性能问题,需要系统性地进行性能分析与瓶颈诊…

    2025年12月6日 开发工具
    000
  • VSCode的悬浮提示信息可以自定义吗?

    可以通过JSDoc、docstring和扩展插件自定义VSCode悬浮提示内容,如1. 添加JSDoc或Python docstring增强信息;2. 调整hover延迟与粘性等显示行为;3. 使用支持自定义提示的扩展或开发hover provider实现深度定制,但无法直接修改HTML结构或手动编…

    2025年12月6日 开发工具
    000
  • VSCode插件:GitLens使用详解

    GitLens是VSCode中强大的Git增强插件,提供行级代码追踪、提交历史浏览、版本对比、跨文件导航及与GitHub等平台集成;通过启用Current Line Blame和In-Line Blame,可实时查看每行代码的作者与修改时间;支持按分支、作者过滤提交记录,比较差异,并利用Go Bac…

    2025年12月6日 开发工具
    000
  • VSCode调试:快速定位与修复问题

    掌握VSCode调试技巧可提升开发效率。首先设置断点并配置launch.json文件,通过“运行和调试”面板启动调试;程序暂停时利用变量窗格查看数据状态,结合调用栈追溯函数执行路径;使用调试控制台动态执行代码、验证逻辑;针对高频调用场景,可设置条件断点(如i===100)或日志断点输出信息而不中断执…

    2025年12月6日 开发工具
    000
  • VSCode界面优化:精简布局与元素

    通过隐藏冗余组件和调整视觉元素可提升VSCode专注度。依次操作:1. 用Ctrl+B和Ctrl+J快捷键或设置隐藏侧边栏与面板;2. 在设置中关闭活动栏显示,并在settings.json中设置”window.titleBarStyle”: “inline&#8…

    2025年12月6日 开发工具
    000
  • VSCode后端:Flask应用调试指南

    答案:配置VSCode调试Flask需安装Flask、编写入口文件、在launch.json中设置调试参数,然后设断点并启动调试会话。具体步骤包括创建launch.json文件并配置program、env和args等选项,确保使用正确Python解释器,避免端口占用,最后通过运行和调试面板启动应用,…

    2025年12月6日 开发工具
    000
  • VSCode调试技巧:断点与变量监控

    VSCode调试功能强大,断点设置与变量监控是核心。2. 点击行号设断点,右键可配条件或日志断点,侧边栏统一管理。3. 暂停时通过变量面板、悬停提示、监视表达式实时查看值。4. 调用栈面板展示函数执行路径,点击可查各层上下文。5. 综合运用这些技巧能高效定位逻辑问题,提升调试效率。 调试是开发过程中…

    2025年12月6日 开发工具
    000
  • 如何管理和同步VSCode的扩展配置,以便在新设备上快速恢复开发环境?

    使用 Settings Sync 是最快方式,通过 GitHub 账号同步扩展、设置、快捷键和代码片段;也可手动导出扩展列表(code –list-extensions > extensions.txt)并在新设备安装,结合备份 settings.json 等配置文件实现环境快速恢…

    2025年12月6日 开发工具
    000
  • VSCode扩展包管理依赖解析

    VSCode扩展依赖通过package.json中的extensionDependencies声明,安装时自动解析并提示用户安装所需扩展,确保按顺序激活且禁止循环依赖,依赖间通过contributes.api共享功能,使用vsce打包时需手动处理生产依赖和性能优化,最终实现扩展间的协同运行与API调…

    2025年12月6日 开发工具
    000
  • VSCode代码转换:编码格式处理

    遇到乱码时先查看文件编码,点击右下角编码名称选择“通过编码重新打开”,尝试 UTF-8、GBK 等常用编码以正确显示内容;2. 确认后可选择“通过编码保存”将文件转换为 UTF-8 等标准编码,便于跨平台协作;3. 为避免重复操作,可在设置中将 “files.encoding&#8221…

    2025年12月6日 开发工具
    000
  • VSCode插件更新:保持功能兼容性

    更新VSCode插件需确保兼容性,避免配置失效或冲突。建议更新前检查依赖关系、阅读变更日志,确认API与版本适配;优先在预发布环境测试新版本;对关键项目通过extensions.json锁定推荐版本;更新后监控命令、语言服务等运行状态,发现问题及时回退。合理管理更新节奏可兼顾新特性与稳定性。 更新V…

    2025年12月6日 开发工具
    000
  • VS Code扩展生态剖析:API设计与商店发布全流程指南

    VS Code扩展成功源于其插件化架构与丰富API。通过Activation Events、Contribution Points和Extension Host实现高效稳定的功能扩展,结合vscode.commands、languages、window、workspace等核心API提供完整开发支持…

    2025年12月6日 开发工具
    000
  • VSCode快捷键:括号与缩进处理

    VSCode默认自动补全括号引号,可用Ctrl+Z撤销或设置中关闭;2. Enter或→可跳过自动闭合符号;3. Tab和Shift+Tab用于调整选中行的缩进;4. Shift+Alt+F格式化文件或选中代码,可设保存时自动格式化;5. 光标靠近括号时高亮匹配,Ctrl+Shift+快速跳转配对括…

    2025年12月6日 开发工具
    000
  • VSCode时间线:文件修改历史与代码追溯系统

    时间线功能是VSCode内置的代码追溯工具,通过整合Git历史记录提供文件修改的时间轴视图。用户可查看提交哈希、作者、时间、提交信息及变更行数,点击记录预览差异并还原版本。该功能依赖Git仓库,支持查看某行修改者、对比历史版本、恢复误删代码等操作,未启用Git时仅显示本地保存点。结合GitLens等…

    2025年12月6日 开发工具
    000
  • VS Code配置作用域:机器特定与资源限定设置

    机器特定设置用于本地环境配置,如终端变量和Python路径,存储于用户配置目录,不共享;资源限定设置存于项目.vscode/settings.json,可共享并确保团队代码风格统一,优先级更高。应根据个性化需求与项目规范选择作用域,敏感信息需结合env文件管理。 VS Code 支持多种配置作用域,…

    2025年12月6日 开发工具
    000
  • 如何配置VSCode以支持对容器内应用程序的远程调试?

    答案是使用VSCode Remote – Containers扩展结合Docker实现远程调试。首先安装Docker、VSCode及Remote – Containers扩展,然后在项目根目录创建.devcontainer文件夹并配置devcontainer.json,指定基…

    2025年12月6日 开发工具
    000
  • 构建VSCode金融量化交易环境与实时数据回测

    搭建基于VSCode的金融量化交易环境需先配置Python及VSCode相关扩展,再创建虚拟环境并安装依赖;接着通过AKShare等工具接入历史与实时数据;随后使用Backtrader构建双均线策略并回测;最后对接实盘接口实现自动化交易,形成完整工作流。 搭建一个基于VSCode的金融量化交易环境,…

    2025年12月6日 开发工具
    000

发表回复

登录后才能评论
关注微信