vdi
v1.7.0
Published
vue3 Dependency injection And some small functions
Downloads
74
Readme
Vdi
一个简单的 vue di 插件,基于@wendellhu/redi
实现
破坏性更新
1.0版本删除了vue-module,overlay相关的api,如果你在使用vue-module overlay请继续留在0.5.0版本
安装
$ npm install @wendellhu/redi vdi
功能
更好的依赖注入
基于redi
增强 vue3 依赖注入简单使用,非侵入
最少两个 api 就可以完成强大的依赖注入
例子
简单使用
创建服务
// count.service.ts
import { ref } from 'vue'
export class CountService {
count = ref<number>(0)
inc() {
this.count.value++
}
}
页面注入并使用
<!--Father.vue -->
<script setup lang="ts">
import { onProvider, useDependency } from 'vdi'
import { CountService } from './count.service'
//在当前组件注入依赖
onProvider([[CountService]])
//获取提供的依赖,self为true时候获取的是当前组件的依赖
const countService = useDependency(CountService, { self: true })
</script>
<template>
{{ countService.count }}
<button @click="countService.inc">修改</button>
</template>
在子组件使用
<!--Child.vue -->
<script setup lang="ts">
import { onProvider, useDependency } from 'vdi'
import { CountService } from './count.service'
//获取提供的依赖,不需要使用self,因为父组件已经注入了依赖
const countService = useDependency(CountService)
</script>
<template>
<div class="child">
子组件: {{ countService.count }}
<button @click="countService.inc">count+</button>
</div>
</template>