Vue3 组件管理 12 种神仙写法,灵活使用才能提高效率

SFC 单文件组件

顾名思义,就是一个.vue文件只写一个组件

模板写法

如果这个组件想要在别的组件里使用,就需要在另一个.vue中引入和使用、复用

h函数写法

使用 defineComponent + h 去进行组件编写

JSX/TSX写法

使用 defineComponent + JSX/TSX 去进行组件编写

pnpm i @vitejs/plugin-vue-jsx -D

安装完毕后,需要在 vite.config.ts 中去进行插件配置

引入组件

单文件多复用模板

如果你想要在一个单文件组件中,定义一些可复用的模板代码的话,可以试试以下的方法

createReusableTemplate

这是 VueUse 提供的一个 Hooks

文档地址:https://vueuse.org/core/createReusableTemplate/

使用方式如下:

namedTemplate

namedTemplateVue Macros 推出的一个前瞻性的 Vue3 特性

虽然Vue Macros里的特性暂时还不是正式版特性,但是以后有很大概率会成为正式版特性

我们也可以对 Vue3 项目进行配置,使得项目可以使用 Vue Macros的特性

文档地址:https://vue-macros.dev/zh-CN/features/named-template.html

使用方式如下:

通用的多组件管理

你可以将多个逻辑紧密或者类型相似的组件,放置在同一个ts文件或Hooks中去管理,在使用到这些组件的地方去引入即可使用~

FunctionalComponent + h

在某一个页面中,如果你有一些组件,它们逻辑比较紧密联系,那你可以使用FunctionalComponent + h将他们封装在同一个 Hooks 中,比如下面的例子

或者你不想写在Hooks中,你也完全可以写在最外层

只不过引入方式就要做一些改变

defineComponent + h

defineComponent + h 的写法也是差不多的道理

你可以使用 Hooks 去封装,如下:

或者你也可以直接放在ts文件最外层

也是同样的效果:

defineComponent + JSX/TSX

可能会有人觉得 h 写起来很麻烦,嵌套太多的话写起来会很难受,那我们其实也可以用JSX/TSX去替代它

同样你也可以将多个组件以JSX/TSX的形式,维护在同一个tsx文件中

pnpm i @vitejs/plugin-vue-jsx -D

安装完毕后,需要在 vite.config.ts 中去进行插件配置

配置完就可以写 TSX 啦!!!

同样你也可以写在外层(这里就不写了,同理)

也是同样的效果:

Vue Macros 组件 API

Vue Macros里的特性暂时还不是正式版特性,但是以后有很大概率会成为正式版特性

文档:https://vue-macros.dev/zh-CN/

defineRender + JSX/TSX

文档地址:https://vue-macros.dev/zh-CN/macros/define-render.html#definerender

defineRenderdefineComponent 的区别在于,defineRender只需要关心最终的DOM结构,不需要管状态的维护

setupSFC + JSX/TSX

文档地址:https://vue-macros.dev/zh-CN/macros/setup-sfc.html#setupsfc

想使用 setupSFC 的特性,需要建一个.setup.tsx/.setup.jsx 文件,跟普通的 tsx/jsx 文件相比,每次引入.setup.tsx/.setup.jsx这个文件,都是一个新的组件实例,状态并不会共享

setupComponent + JSX/TSX

文档地址:https://vue-macros.dev/zh-CN/macros/setup-component.html#setupcomponent

setupComponent 适合用来管理多组件,可以把多个紧密联系或共用的组件,通过setupComponent写在同一个文件或 Hooks 里

setupComponent中可以使用setup的语法去写逻辑,写起来比defineComponent简洁很多

同理,你想写在文件外层也行~这里就不具体写了

Vine

文档:https://vue-vine.dev/

这个库的作用就是:让 Vue 组件能通过函数式来定义

举个例子,我们在平时写一个组件的时候,会通过模板的方式去定义

但是在使用了 Vue-Vine这个库之后,可以使用函数式的方式去定义

翻看了一下Vue-Vine的官方文档,总结出Vue-Vine这个库的初衷是:

  • 想要做到像 React JSX 那样的组件定义方式

  • 可以在同个文件里定义多个组件

  • 使得逻辑更加聚合,提高开发效率

总结

Vue 的组件有很多写法,合适的场景选择合适的写法,才能更好地提高开发效率~而不是死定硬背

相关推荐
桂月二二28 分钟前
探索前端开发中的 Web Vitals —— 提升用户体验的关键技术
前端·ux
CodeClimb1 小时前
【华为OD-E卷 - 第k个排列 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
沈梦研1 小时前
【Vscode】Vscode不能执行vue脚本的原因及解决方法
ide·vue.js·vscode
hunter2062062 小时前
ubuntu向一个pc主机通过web发送数据,pc端通过工具直接查看收到的数据
linux·前端·ubuntu
qzhqbb2 小时前
web服务器 网站部署的架构
服务器·前端·架构
刻刻帝的海角2 小时前
CSS 颜色
前端·css
轻口味2 小时前
Vue.js 组件之间的通信模式
vue.js
浪浪山小白兔3 小时前
HTML5 新表单属性详解
前端·html·html5
lee5763 小时前
npm run dev 时直接打开Chrome浏览器
前端·chrome·npm
2401_897579653 小时前
AI赋能Flutter开发:ScriptEcho助你高效构建跨端应用
前端·人工智能·flutter