Maison >outils de développement >VSCode >Combat pratique : développer un plug-in dans vscode qui prend en charge les fichiers vue pour accéder aux définitions
vscode
vscode
自身是支持vue文件组件跳转到定义的,但是支持的力度是非常弱的。我们在vue-cli
的配置的下,可以写很多灵活的用法,这样可以提升我们的生产效率。但是正是这些灵活的写法,导致了vscode自身提供的功能无法支持跳转到文件定义。为了兼容这些灵活的写法,提高工作效率,所以写了一个vscode支持vue文件跳转到定义的插件。【推荐学习:《vscode教程》】
vscode支持vue文件跳转到定义的插件(vue jumper
)已正式发布到vscode插件市场,可以到vscode插件市场直接下载体验。
该插件支持vue-cli提供给我们很多组件引用写法的跳转支持。
我们在引用组件的时候,如果组件的名称是index.vue
或者index.js
时,我们引入时可以省略index.vue或者index.js。如果我们使用了省略写法,vscode自身是无法支持跳转的,所以该插件需要支持省略写法跳转。
import MycoMponent from '../components/MyComponent' // '../components/MyComponent/index.vue'
在vue-cli(webpack)的配置下,我们可以配置alis别名,这样我们可以提升生产效率,但是vscode本身是不支持的,所以该插件需要支持alis别名路径跳转。
import MycoMponent from '@/components/MyComponent'
vscode本身是支持components注册别名跳转的(如果引入时有省略写法和alis别名路径也是不支持的),所以该插件也需要支持components注册别名跳转。
<script> import MycoMponent from &#39;@/components/MyComponent&#39; export default { components: { MycoMponentReName: MycoMponent } } </script>
在实际开发中,我们可以有很多复用的功能抽离到了mixins
lui-même prend en charge les composants du fichier vue pour accéder à la définition, mais la prise en charge est très faible. Sous la configuration de vue-cli
, nous pouvons écrire de nombreuses utilisations flexibles, ce qui peut améliorer notre efficacité de production. Mais ce sont ces méthodes d'écriture flexibles qui empêchent les fonctions fournies par vscode lui-même de prendre en charge le passage aux définitions de fichiers. Afin d'être compatible avec ces méthodes d'écriture flexibles et d'améliorer l'efficacité du travail, j'ai écrit un plug-in vscode qui prend en charge les fichiers Vue pour accéder aux définitions. [Apprentissage recommandé : "vscode tutoriel
vue jumper
) a été officiellement publié sur le marché des plug-ins vscode, vous pouvez Accédez au marché des plug-ins vscode pour le télécharger et en faire l'expérience directement.
index.vue
ou index.js
, nous pouvons omettre index.vue ou index.js lors de son introduction. Si nous utilisons la méthode d'écriture omise, vscode lui-même ne peut pas prendre en charge les sauts, le plug-in doit donc prendre en charge les sauts de méthode d'écriture omise. 🎜<template> <MyComponent /> </template> <script> import myMixins from '@/mixins/myMixins' export default { mixins: [myMixins] } </script>
// myMixins.js import MycoMponent from '@/components/MyComponent' export default { components: { MycoMponent } }
<template> <MyComponent /> </template> <script>
mixins code>, qui incluent le introduction et enregistrement des composants. Ce vscode lui-même ne prend pas en charge les sauts, le plug-in prend donc en charge l'introduction de mixins. 🎜<pre class="brush:js;toolbar:false;">// main.js
import vue from &#39;vue&#39;
import MycoMponent from &#39;./components/MyComponent&#39;
vue.use(MycoMponent)</pre>rrreee🎜🎜5. Les composants globaux introduisent la prise en charge des sauts🎜🎜🎜Pour les composants enregistrés globalement, vscode lui-même ne prend pas en charge les sauts dans ce cas. Étant donné que l'introduction de composants globaux est relativement complexe, le plug-in utilise une recherche floue pour trouver l'endroit où le composant est défini et permet d'obtenir une prise en charge rapide pour l'introduction de composants globaux. 🎜rrreeerrreee🎜Pour plus de connaissances sur VSCode, veuillez visiter : 🎜Tutoriel de base de vscode🎜 ! 🎜🎜
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!