「我们一起做组件库🌻」做个面包屑🥖,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和依赖注入的对比

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

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

相关推荐
dorisrv1 小时前
优雅的React表单状态管理
前端
蓝瑟1 小时前
告别重复造轮子!业务组件多场景复用实战指南
前端·javascript·设计模式
dorisrv2 小时前
高性能的懒加载与无限滚动实现
前端
韭菜炒大葱2 小时前
别等了!用 Vue 3 让 AI 边想边说,字字蹦到你脸上
前端·vue.js·aigc
StarkCoder2 小时前
求求你,别在 Swift 协程开头写 guard let self = self 了!
前端
清妍_2 小时前
一文详解 Taro / 小程序 IntersectionObserver 参数
前端
电商API大数据接口开发Cris2 小时前
构建异步任务队列:高效批量化获取淘宝关键词搜索结果的实践
前端·数据挖掘·api
符方昊2 小时前
如何实现一个MCP服务器
前端
喝咖啡的女孩2 小时前
React useState 解读
前端
渴望成为python大神的前端小菜鸟2 小时前
浏览器及其他 面试题
前端·javascript·ajax·面试题·浏览器