【必备】用VSCode开发Vue程序必备插件之一Vue Language Features (Volar)

2023-10-07 20:36

本文主要是介绍【必备】用VSCode开发Vue程序必备插件之一Vue Language Features (Volar),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

通过安装该插件

才能通过赚到编辑器中的符号


Vue Language Features 是为 Vue、Vitepress 和 petite-vue 构建的语言支持扩展。这是基于@vue/reactivity按需计算一切,实现原生 TypeScript 语言服务级别性能。

[温馨提示]

快速开始

  • 创建 vue
  • 维特斯
  • 娇小的
  • vue3-eslint-stylelint-demo(Volar + ESLint + stylelint + husky)
  • volar-starter(用于错误报告和实验功能测试)

用法

Vue 2 的设置

  1. 添加@vue/runtime-dom

此扩展需要@vue/runtime-dom.

Vue 3 和 Vue 2.7 具有内置的 JSX 类型。对于 Vue 版本 <= 2.6.14,您需要通过 install 添加 JSX 类型@vue/runtime-dom

// package.json
{"devDependencies": {"@vue/runtime-dom": "latest"}
}
  1. 消除Vue.extend

不支持模板类型检查Vue.extend。您可以使用composer-api、vue-class-component或export default { ... }代替export default Vue.extend.

以下是不同编写脚本块方式的兼容性表:

组件选项类型检查<script>插值类型检查<template>跨组件 props 类型检查
export default { ... }与JS不支持不支持不支持
export default { ... }与 TS不支持支持但已弃用支持但已弃用
export default Vue.extend({ ... })与JS不支持不支持不支持
export default Vue.extend({ ... })与 TS有限(支持data类型但不支持props类型)有限的不支持
export default defineComponent({ ... })支持的支持的支持的
类组件支持的通过附加代码支持 ( #21 )通过附加代码支持

请注意,您defineComponent甚至可以使用使用Options API.

  1. 支持 Vue 2 模板

Volar优先支持Vue 3。Vue 3和Vue 2模板有一些差异。您需要设置选项target以支持 Vue 2 模板。

// tsconfig.json
{"compilerOptions": {// ...},"vueCompilerOptions": {"target": 2.7,// "target": 2, // For Vue version <= 2.6.14}
}
  1. 删除.d.ts文件(如果存在)。

对于Vue CLI生成的项目,.d.ts包含文件。删除这些文件。

rm src/shims-tsx.d.ts src/shims-vue.d.ts

定义全局组件

公关:https: //github.com/vuejs/vue-next/pull/3399

本地组件、内置组件、原生 HTML 元素无需配置即可进行类型检查。

对于全局组件,需要定义GlobalComponents接口,例如:

// components.d.ts
declare module 'vue' {  // Vue >= 2.7
// declare module '@vue/runtime-dom' {  // Vue <= 2.6.14export interface GlobalComponents {RouterLink: typeof import('vue-router')['RouterLink']RouterView: typeof import('vue-router')['RouterView']}
}export {}

笔记

维图尔

您需要禁用 Vetur 以避免冲突。

推荐使用 css / less / scss 作为<style>语言,因为这些基于vscode-css-languageservice提供可靠的语言支持。

如果使用 postcss / stylus / sass,则需要安装额外的扩展以进行语法高亮。我试过了,有效,你也可以选择其他的。

  • postcss:语言-postcss。
  • 手写笔:语言手写笔
  • 萨斯:萨斯

Volar 不包含 ESLint 和 Prettier,但官方ESLint和Prettier扩展支持 Vue,因此您可以根据需要自行安装这些扩展。

如果使用 Vetur 的可自定义脚手架片段,建议使用片段生成器转换为 VSCode 片段。如果您更喜欢无需自定义的现成片段,VSCode Marketplace 上也有一些片段,例如 Sarah Drasner 的Vue VSCode Snippets 。

class如果 VSCode 给出如下错误slot

这是因为您的项目中安装的软件包之一使用了它@types/react,这破坏了 Volar 的某些部分。

请参阅以下解决方案:

  • JSX issues in template · vuejs/language-tools · Discussion #592 · GitHub
  • JSX issues in template · vuejs/language-tools · Discussion #592 · GitHub

递归组件

由于 TS 限制,Volar 无法开箱即用地对递归组件进行类型检查。但有一个解决方法,您可以显式指定组件的 props,如下所示:

Bar.vue

<template><Bar :a="'wrong'" />
</template><script setup lang="ts">
import { defineAsyncComponent, type DefineComponent } from 'vue'interface Props {a: number
}const Bar = defineAsyncComponent<DefineComponent<Props>>(() => import('./Bar.vue') as any
)
defineProps<Props>()
</script>

自定义文件扩展名

语法突出显示和智能感知可以应用于除vue. 这需要在三个不同的地方进行配置才能获得全面支持。

在 Volar 扩展的 VS Code 设置中添加您需要的任何其他扩展Additional Extensions。比如ext

在 tsconfig.json 文件中,您需要确保 TypeScript 包含您的自定义扩展。如果您有一个包含值,那么您也./src/*.vue想添加一个包含值。./src/*.ext

"include": ["./src/*.ts","./src/*.vue","./src/*.ext",
]

最后,您需要让 VS Code 识别您的新扩展并自动将其与 Vue 语言格式关联。为此,您需要配置文件关联设置以映射*.ext到语言值vue。这可以在“文本编辑器”>“文件”下或使用 键来完成files.associations

制作人员

  • vscode-extension-samples显示了开发扩展所需的所有知识。
  • Angular展示了 TS 服务器插件如何与语言服务配合使用。
  • 语法高亮是在vue-syntax-highlight 的基础上重写的。
  • vscode-fenced-code-block-grammar-injection-example展示了如何将 vue 语法高亮注入到 markdown 中。
  • 开箱即用的格式化工作方式(如果您想使用其他格式化程序,请查看https://github.com/vuejs/language-tools-plugins):
    • vscode-html-语言服务:html
    • vscode-css-语言服务:css、less、scss、postcss
    • 哈巴狗美化: 哈巴狗
    • 打字稿:js、ts、jsx、tsx

【推荐】Vue代码格式化插件Vue 3 Support - All In One_你挚爱的强哥的博客-CSDN博客会将同一个节点里面的不同属性换行排列对齐,这样看起来更加清晰,尤其是一个节点绑定十几个属性、事件的时候,这样的排列方式更有效、快捷进行修改、删除。https://blog.csdn.net/qq_37860634/article/details/133632844

这篇关于【必备】用VSCode开发Vue程序必备插件之一Vue Language Features (Volar)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/160271

相关文章

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加