vue知识点总结 依赖注入 动态组件 异步加载

一 依赖注入

使用场景:当需要多层组件需要传值 如 祖宗-》父亲-》儿子-》孙子 如祖宗的数据需要直接传给孙子

祖宗组件中写:

javascript 复制代码
data(){return {}}
provide(){
return {
    shujukey:'数据值'
}
}

孙子 组件中接收,模板代码中直接使用{``{shujukey}}获取数据

javascript 复制代码
data(){return {}}
inject:['shujukey']

如果想全局使用某个依赖数据,需要在main.js中修改代码createApp(App).mount('#app')

javascript 复制代码
const app=createApp(App);
app.provide('zuzongName','zuzongvalue')
app.mount('#app')

二 动态组件 异步加载

dom中

javascript 复制代码
 <component :is="mycomponent"></component>
 <button @click="turntab">切换组件</button>

js中

javascript 复制代码
import componentA from "./componentA.vue";
// import componentB from "./componentB.vue";
const componentB = defineAsyncComponent(() => import("./componentB.vue"));//异步加载

data(){
	mycomponent:'componentA'
},
methods:{
turntab(){
 this.mycomponent =
        this.mycomponent === "componentA" ? "componentB" : "componentA";
}
}

如在切换组件的过程中不想叫组件销毁,可以使用

保持组件存活

javascript 复制代码
<keep-alive>
    <component :is="mycomponent"></component>
</keep-alive>
相关推荐
北辰alk4 分钟前
Vue 模板引擎深度解析:基于 HTML 的声明式渲染
vue.js
北辰alk13 分钟前
Vue 自定义指令完全指南:定义与应用场景详解
vue.js
yinuo21 分钟前
前端跨页面通讯终极指南⑨:IndexedDB 用法全解析
前端
北辰alk34 分钟前
Vue 动态路由完全指南:定义与参数获取详解
vue.js
北辰alk1 小时前
Vue Router 完全指南:作用与组件详解
vue.js
北辰alk1 小时前
Vue 中使用 this 的完整指南与注意事项
vue.js
xkxnq1 小时前
第二阶段:Vue 组件化开发(第 16天)
前端·javascript·vue.js
北辰alk1 小时前
Vue 插槽(Slot)完全指南:组件内容分发的艺术
vue.js
烛阴1 小时前
拒绝配置地狱!5 分钟搭建 Three.js + Parcel 完美开发环境
前端·webgl·three.js
北辰alk1 小时前
Vue 组件中访问根实例的完整指南
vue.js