使用 Prettier、TypeScript、Vuejs 和 VSCode 设置 ESLint 自动保存自动格式

使用 prettier、typescript、vuejs 和 vscode 设置 eslint 自动保存自动格式

本指南将引导您使用 eslint 9.13.0、prettier 和 typescript 配置 vue.js 项目,以在 visual studio code 中保存时启用自动代码格式化和 linting。

1.创建一个新的vue项目

首先创建一个新的 vue 项目:

npm create vue@latest

导航到项目目录:

cd your-project-directory

2. 安装和更新依赖项

安装项目依赖项:

npm install

然后,使用ncu(node check updates)更新项目依赖项:

npx ncu -unpm install

3.先决条件添加eslint、prettier和typescript包

此配置需要在本地或全局安装以下 npm 软件包:

prettiereslint prettier-eslint@typescript-eslint/parsertypescript vue-eslint-parser@vue/eslint-config-typescript @vue/eslint-config-prettier

使用 pnpm 或 npm 安装必要的开发依赖项:

pnpm install -d prettier eslint prettier-eslint @typescript-eslint/parser typescript vue-eslint-parser @vue/eslint-config-typescript @vue/eslint-config-prettier

4.初始化eslint配置

运行以下命令来设置 eslint 配置:

npm init @eslint/config@latest

出现提示时,进行以下选择来配置 eslint:

您想如何使用 eslint?:检查语法并发现问题。您的项目使用什么类型的模块?:commonjs(需要/导出)。您的项目使用哪个框架?:vue.js。您的项目使用 typescript 吗?:是的。你的代码在哪里运行?:浏览器。当询问您是否要安装依赖项(eslint、globals、@eslint/js、@typescript-eslint、eslint-plugin-vue)时,选择 并使用 npm 作为包管理器。

5.添加eslint平面配置

为了确保 eslint 使用新的 flat config 格式,请确保在 eslint.config.mjs 文件中包含必要的配置。对此的调整可能取决于您的具体设置。

import globals from 'globals';import pluginjs from '@eslint/js';import tseslint from 'typescript-eslint';import pluginvue from 'eslint-plugin-vue';import prettier from 'eslint-plugin-prettier/recommended';import vueconfigtypescript from '@vue/eslint-config-typescript';import vueconfigprettier from '@vue/eslint-config-prettier';/** @type {import('eslint').linter.config[]} */export default [  {    languageoptions: {      globals: {        ...globals.browser,        ...globals.node,      },    },  },  // js  pluginjs.configs.recommended,  {    rules: {      'no-unused-vars': 'off',      'no-undef': 'off',    },  },  // ts  ...tseslint.configs.recommended,  {    rules: {      '@typescript-eslint/no-unused-vars': 'warn',      '@typescript-eslint/no-explicit-any': 'warn',    },  },  // vue  ...pluginvue.configs['flat/recommended'],  {    files: ['*.vue', '**/*.vue'],    languageoptions: {      parseroptions: {        parser: tseslint.parser,      },    },  },  {    rules: {      ...vueconfigtypescript.rules,      ...vueconfigprettier.rules,      'prettier/prettier': [        'warn',        {          singlequote: true,        },      ],      'vue/multi-word-component-names': 'off',      'vue/attribute-hyphenation': 'off',      'vue/no-v-html': 'off',      'vue/v-on-event-hyphenation': 'off',      '@typescript-eslint/ban-ts-comment': 'off',      '@typescript-eslint/no-require-imports': 'off',      '@typescript-eslint/no-explicit-any': 'off',    },  },  {    ignores: ['node_modules', '.nuxt', '.output', 'dist'],  },  // prettier  prettier,  {    rules: {      'prettier/prettier': ['warn', { singlequote: true }],    },  },];

6. 安装 vscode 扩展以进行 prettier-eslint 集成

要使用 prettier 和 eslint 启用保存时自动格式化,请安装以下 visual studio code 扩展:

prettier eslint:在这里下载

7.添加扩展推荐

要为您的项目推荐扩展,请将其添加到 .vscode/extensions.json 文件中:

{  "recommendations": [    "rvest.vs-code-prettier-eslint"  ]}

8. 重启vscode

配置项目并安装扩展后,重新启动 visual studio code 以确保自动保存和自动格式化按预期工作。

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

概括

您的项目现在应该设置为:

eslint 9.13.0,支持 typescript 和 vue.js更漂亮的集成以实现一致的代码格式使用 prettier eslint 扩展在 vscode 中保存时自动格式化

以上就是使用 Prettier、TypeScript、Vuejs 和 VSCode 设置 ESLint 自动保存自动格式的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
JavaScript 中 this 指向的谜团:调用与赋值的区别?
上一篇 2025年12月19日 17:48:35
多个项目共用导航栏:使用母版页还是单页面应用程序?
下一篇 2025年12月19日 17:48:47

相关推荐

  • Matplotlib 地图中多类型图例的创建与优化

    Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化

    本教程旨在解决matplotlib地图可视化中,如何在一个图例中同时展示颜色块(如区域分类)和自定义标记(如特定兴趣点)的问题。文章详细介绍了当传统`patch`对象无法正确显示标记时,如何利用`matplotlib.lines.line2d`创建标记图例句柄,并将其与颜色块图例句柄合并,从而生成一…

    2026年5月10日 用户投稿
    100
  • vscode上怎么运行html_vscode上运行html步骤【指南】

    首先保存文件为.html格式,再通过浏览器或Live Server插件打开预览;推荐安装Live Server实现本地服务器运行与实时刷新,提升开发体验。 在 VS Code 上运行 HTML 文件并不需要复杂的配置,只需几个简单步骤即可预览页面效果。VS Code 本身是一个代码编辑器,不直接运行…

    2026年5月10日
    100
  • JS注解怎么和TypeScript结合_ JS注解在TypeScript环境下的应用

    TypeScript 支持通过配置 allowJs 和 checkJs 在 JavaScript 文件中识别 JSDoc 注解并进行类型检查,可在混合项目中提升类型安全;常见用法包括 @type、@param、@returns 和 @typedef,能为变量、函数参数等提供类型信息,支持与 .ts …

    2026年5月10日
    000
  • Go语言与Microsoft SharePoint集成指南

    Go语言可以有效集成Microsoft SharePoint,主要通过两种途径:一是利用SharePoint提供的RESTful API进行数据交互,Go的标准HTTP客户端库即可轻松实现;二是通过SharePoint应用模型开发自托管应用,这种模型支持使用包括Go在内的任何语言编写后端逻辑。 1.…

    2026年5月10日
    000
  • javascript生命周期钩子是什么_组件有哪些关键阶段?

    JavaScript原生无生命周期钩子,这是Vue、React等框架为组件设计的机制;Vue按创建、挂载、更新、卸载四阶段提供对应钩子,React类组件有明确生命周期方法,函数组件则通过useEffect模拟,其核心价值在于精准控制执行时机以避免DOM操作错误和内存泄漏。 JavaScript 本身…

    2026年5月10日
    100
  • HTML结构错误解析与W3C验证器指南

    本文旨在深入解析常见的html结构错误,特别是涉及` `、“和` `元素的不当使用,这些错误常导致w3c验证器报错。我们将详细阐述这些元素的正确语义和放置规则,解释隐式闭合机制如何引发验证问题,并通过实际代码示例展示如何构建符合标准、易于维护的html文档,从而提升网页的兼容性和可访问性…

    2026年5月10日
    000
  • 前后端分离项目中,如何解决“net::ERR_CONNECTION_REFUSED”错误?

    修复“bug:net::err_connection_refused”后端代码中的错误 在开发前后端分离项目时,使用vue2前端和fastapi后端,前端希望通过“http://10.96.67.161:8081/uploadimg/”接口传输图片给后端,但遇到了“post http://10.96…

    2026年5月10日
    000
  • 让我们只用一根安装线就可以使网络响应起来吗?我正在寻找贡献者!

    最近我发布了一个 npm 包,其使命如标题所示:让项目只需一行代码即可响应! 我与您分享响应式应用程序 [beta] 包 我花了几年时间尝试和开发这项技术,目前包括: 动态设置 html 标签字体大小(通过 js 脚本),考虑:(1) 屏幕分辨率和 (2) 浏览器字体大小(用于网络可访问性)将像素定…

    2026年5月10日
    000
  • TypeScript函数体中如何高效判断参数类型?

    typescript 函数体中判断参数类型的技巧 typescript 中,我们可以定义接口来表示不同的数据类型。在本文中,我们将探讨如何在函数体中判断参数的类型,从而实现类型收窄,进行更精细的类型检查。 使用谓词函数 一种方法是编写谓词函数来手动检查类型。谓词函数返回的是 value is som…

    2026年5月10日
    000
  • JS如何实现策略模式

    策略模式通过封装算法使其可互换,JavaScript中利用函数作为一等公民实现,适用于表单验证等场景,结合工厂模式提升灵活性,但应避免过度设计。 策略模式的核心在于定义一系列算法,并将每一个算法封装起来,使它们可以相互替换。这使得算法可以在不影响客户端的情况下发生变化。在JS中,这可以通过函数作为一…

    2026年5月10日
    000
  • 如何在H5环境中实现EXCEL和Word文件的在线预览?

    H5环境下EXCEL和Word文件在线预览技术详解 在如今的Web应用中,在线预览文档功能至关重要,尤其对于需要处理大量文件的企业应用。本文将介绍两种无需插件,直接在浏览器中预览EXCEL和Word文件的方法。 企业对在线文档预览的需求日益增长,以提高效率和协同性。下面我们探讨两种有效的H5在线预览…

    2026年5月10日
    000
  • vscode怎么运行html选择浏览器_vscode选浏览器运html法【教程】

    使用Live Server插件可在VS Code中运行HTML文件并指定浏览器。1. 安装Live Server插件后右键HTML文件选择Open with Live Server即可在默认浏览器中预览。2. 通过设置Live Server的Browser选项为chrome、firefox或edge…

    2026年5月10日
    100
  • Svelte中正确导入数据与组件:避免常见误区

    在svelte开发中,理解如何正确导入数据和组件至关重要。svelte文件定义的是组件而非普通javascript模块,若需共享纯数据,应使用`.js`文件进行导出。本文将详细阐述svelte的导入机制,并通过示例代码展示如何区分导入数据与渲染组件,从而避免常见的导入错误,确保项目结构清晰且功能正确…

    2026年5月10日
    300
  • 小程序如何自动切换语言,才能兼顾精准性和适用性?

    根据小程序实现自动切换语言 对于多语言环境的小程序,如何自动切换语言是一个常见问题。 方法一:根据用户定位 这种方法基于用户定位来获取所在国家,并根据国家对应语言设置。然而,这种方法存在一定的局限性,如用户可能不会允许位置共享。 方法二:通过 wx.getsysteminfo 这是微信官方提供的 a…

    2026年5月10日
    000
  • WebView2 无法接收打包 Vue 项目数据:如何解决 C# 与 Vue 项目通信问题?

    webview2 无法接收打包 vue 项目发送的数据 在使用 webview2 嵌入 vue 项目时,开发者可能会遇到无法接收 c# 传输的数据的问题。要解决此问题,首先需要检查 webview2 控件加载的 html 页面的正确性。 一般来说,如果在加载独立的 html 页面(例如 test.h…

    2026年5月10日
    000
  • 如何通过GitHub API高效获取超过100个用户列表(分页教程)

    本教程旨在解决使用GitHub API获取用户列表时遇到的默认100个用户限制问题。我们将详细介绍两种主要的分页策略:利用Octokit库内置的paginate方法实现自动化分页,以及手动实现基于since参数的循环分页逻辑。文章将提供清晰的代码示例,并强调在不同场景下选择合适方法的注意事项,特别是…

    2026年5月10日
    100
  • 前端构建优化:利用常量折叠提升应用性能

    本文深入探讨了一种在构建阶段执行部分源代码以进行优化的技术——常量折叠(Constant Folding)。通过在编译时预计算表达式并替换为最终结果,该技术显著减少了运行时开销,提升了应用性能。文章将详细解释其工作原理、优势,并探讨其在现代前端构建工具中的应用与配置,旨在帮助开发者实现更高效的代码优…

    2026年5月10日
    000
  • 动态语言中静态类型的讽刺

    c++kquote>您也可以在 medium 上阅读这篇文章。 当我们看到编程语言如何随着时间的推移而演变时,总是很有趣。 曾几何时,当我开始进入软件开发世界时,python、php 和 javascript 等动态语言因其灵活性和适合快速开发的简洁语法而受到赞赏。 然而,随着这些弱类型语言的…

    2026年5月10日
    000
  • 为什么 TypeScript 比 JavaScript 更好

    javascript 长期以来一直是 web 开发的基石,支持从小型脚本到大型应用程序的各种项目。然而,随着项目规模的扩大,javascript 的动态类型和缺乏结构性可能会成为开发的瓶颈。typescript 应运而生,它凭借静态类型检查和强大的工具集,迅速成为许多开发者构建可靠、可扩展应用程序的…

    2026年5月10日
    100
  • Vue.js前端生成带分页符的Word文档:挑战与解决方案? 或 如何在Vue.js前端生成包含分页符的Word文档?

    vue.js前端生成word文档并插入分页符的难题 许多开发者希望在Vue.js前端直接将HTML转换为包含分页符的Word文档。本文分析实现此目标的方法以及面临的挑战。 用户尝试使用page-break-after: always属性(或其替代属性break-after)在生成的Word文档中添加…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信