Vue3.0如何在 自定义指令中,插入组件

发布于 2022-09-12 23:28:34 字数 694 浏览 20 评论 0

问题描述

Vue3.0中使用自定义指令,如何在使用指令的元素上插入 组件

相关代码

  • loading.vue
<template>
    <!--loading-->
</template>
<script>
    /*loading*/
</script>
  • main.js
...
import Loading from '../loading.vue'
app.directive('loading',(el,binding) => {
    let loading = binding.value;
    /*如何将组件loading挂载到使用组件的el上?**/
})
...
  • 组件中使用
<component v-loading="loading"></component>

<script>
...
setup() {
    let loading = ref(false)
    return {
        loading
    }
}
...
</script>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

并安 2022-09-19 23:28:34

正好最近也在写这个指令。你可以参考下:

import Vue, { createVNode, render } from 'vue';

/**
 * 动态创建组件
 * @param hostEl 组件要挂载到的Dom
 * @param component 组件
 * @param params 组件参数
 */
function createComponent(hostEl: HTMLElement, component: any, params?: any) {
    // 创建虚拟节点
    let vNode: Vue.VNode | null = createVNode(component, params);
    // 渲染并挂载到宿主节点
    render(vNode, hostEl);
    // 销毁方法
    const destroy = () => {
        render(null, hostEl);
        vNode = null;
    };
    return { vNode, destroy };
}

使用时:

import { createComponent } from 'component.service';
import LoadingComponent from 'loading.component.vue';
// 创建组件
const props = {
        // ...
    },
    eventHandlers = {
        onClick: () => {},
        // ...
    },
    params = {
        ...props,
        ...eventHandlers,
    };
const { destroy } = createComponent(el, LoadingComponent, params);

// 销毁组件
destory();
信愁 2022-09-19 23:28:34

题主是不是要写组件,然后通过属性控制

// loading.vue
<template>
    <div class="loading" v-show="loading" />
</template>
<script lang="ts">
    import { defineComponent } from 'vue'
    export default defineComponent({
     props: {
        loading: {
          type: Boolean,
          default: false
        }
      },
    })
</script>
//   组件中使用
<template>
  <Loading :loading="loading" />
</template>
<script lang="ts">
import Loading from './Loading.vue'
import { ref, defineComponent } from 'vue'

export default defineComponent({
  components:{
    Loading,
  },
  setup(){
    const loading = ref(true);
    
    return {
        loading
    }
  }
})
</script>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文