「我们一起做组件库🌻」做个面包屑🥖,Vue的依赖注入实战💉(VersakitUI开发实录)

Hi, 这里是和朋友一起开发组件库的JustHappy ,今天我们来做个面包屑,我觉得这个是一个比较好的案例去体现Vue的依赖注入,还有这是一个"组合式组件",算是一个比较可聊的话题吧,今天我们就来一起看看,这个面包屑是如何实现的吧。

本文为组件库开发分享,可能不会很细致,详细请看源码Breadcrumb源码

如果你想尝试Versakit 可以点击这里去文档

什么是"组合式组件"组件?

我们先来看一下面包屑的使用

像这种由一个外层父元素所包裹的,内部包含一个或者多个Item项的组件,就叫做组合式组件

这该怎么实现呢?其实就是写个父子组件

其实很简单,我们会在父组件index中设置插槽来放置item

具体的代码可以点这去查看Breadcrumb

为什么要使用依赖注入?

想一下,如果要修改面包屑组件的分割符怎么办?也就是把

首页/产品列表/产品详情 变成这样 首页>产品列表>产品详情

如果是使用单纯的父子组件通讯 props的形式呈现出来的代码效果会是下面这样,是不是有点复杂了,只是为了修改分割符

html 复制代码
<VerBreadcrumb separator=">">
  <template v-slot="{ separator }">
    <BreadcrumbItem :separator="separator">首页</BreadcrumbItem>
    <BreadcrumbItem :separator="separator">列表</BreadcrumbItem>
  </template>
</VerBreadcrumb>

我们当然希望可以通过直接在父组件<VerBreadcrumb>标签中设置separator属性就可以配置全部的面包屑分割线。而依赖注入就可以实现以下效果

html 复制代码
<VerBreadcrumb separator=">">
   <VerBreadcrumbItem>首页</VerBreadcrumbItem>
   <VerBreadcrumbItem>产品列表</VerBreadcrumbItem>
   <VerBreadcrumbItem>产品详情</VerBreadcrumbItem>
</VerBreadcrumb>

而且这是支持嵌套的,就像下面这样,也是一样的效果

html 复制代码
<VerBreadcrumb separator=">">
   <VerBreadcrumbItem>首页</VerBreadcrumbItem>
   <VerBreadcrumbItem>产品列表</VerBreadcrumbItem>
   <div>
       <div>
           <VerBreadcrumbItem>产品详情</VerBreadcrumbItem>
       </div>
   </div>
</VerBreadcrumb>

总的来说有这几点好处把:

  • ✅ 降低组件间的耦合度
  • ✅ 简化组件通信
  • ✅ 提高代码的可维护性
  • ✅ 符合最小知识原则,子组件只需要知道注入的 key 即可

什么是依赖注入?

点此直达Vue官方文档

通常情况下,当我们需要从父组件向子组件传递数据时,会使用 props。在一些多层级情况下就需要一层一层的传递这个数据,这对传递数据的节点是没有意义的,还会增加代码的复杂度,于是我们想着可不可以把数据直接从起点通过某种方式直接到达终点,这便是依赖注入,以下是Vue官网的两张截图,很直观体现了Prop和依赖注入的对比

哦对了,如果你也想加入我们有关开发一个组件库的讨论.....

欢迎加入我们的交流群🎉🎉

相关推荐
张晓~1833994812127 分钟前
数字人源码部署流程分享--- PC+小程序融合方案
javascript·小程序·矩阵·aigc·文心一言·html5
爱喝水的小周30 分钟前
AJAX vs axios vs fetch
前端·javascript·ajax
Jinxiansen021133 分钟前
unplugin-vue-components 最佳实践手册
前端·javascript·vue.js
几道之旅36 分钟前
介绍electron
前端·javascript·electron
周胡杰39 分钟前
鸿蒙arkts使用关系型数据库,使用DB Browser for SQLite连接和查看数据库数据?使用TaskPool进行频繁数据库操作
前端·数据库·华为·harmonyos·鸿蒙·鸿蒙系统
315356691339 分钟前
ClipReader:一个剪贴板英语单词阅读器
前端·后端
玲小珑42 分钟前
Next.js 教程系列(十一)数据缓存策略与 Next.js 运行时
前端·next.js
qiyue771 小时前
AI编程专栏(三)- 实战无手写代码,Monorepo结构框架开发
前端·ai编程
轻语呢喃1 小时前
React智能前端:从零开始的识图学单词项目(一)
javascript·react.js·aigc
断竿散人1 小时前
JavaScript 异常捕获完全指南(下):前端框架与生产监控实战
前端·javascript·前端框架