问答

Vue3如何在挂载到全局的插件中使用第三方UI库

作者:admin 2021-05-13 我要评论

需求是一个全局的登录弹窗 在vue2我是extend一个子类,实例化后挂在全局,并把显示弹窗的方法挂在在原型上。 vue2这样写 // plugins/LoginDialog.jsimport Login...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

需求是一个全局的登录弹窗
在vue2我是extend一个子类,实例化后挂在全局,并把显示弹窗的方法挂在在原型上。
vue2这样写

// plugins/LoginDialog.js
import LoginDialogCom from "@/components/LoginDialog.vue";

export default {
  install: function (Vue) {
    const LoginDialogConstructor = Vue.extend(LoginDialogCom);
    const instance = new LoginDialogConstructor();

    instance.$mount(document.createElement("div"));
    document.body.appendChild(instance.$el);

    Vue.prototype.$loginDialog = () => {
      instance.loginVisible = true;
    };
  },
}; 

vue3没有extend,我这样写

// plugins/LoginDialog.js
import LoginDialogCom from '@/components/LoginDialog.vue';

import { createApp } from 'vue';

export default {
  install: (app) => {
    const instance = createApp(LoginDialogCom).mount(
      document.createElement('div')
    );
    document.body.appendChild(instance.$el);
    app.config.globalProperties.$loginDialog = () => {
      instance.loginVisible = true;
    };
  }
};

// main.js
createApp(App).use(Antd).use(loginDialog).mount("#app"); 

被挂载的LoginDialogCom中使用了antdv的模态框,但a-modal无法正确被加载(Failed to resolve component: a-modal),查看elements还是a-modal标签
image

image.png1128×268 30.4 KB
访问↓查看代码
https://codesandbox.io/s/sleepy-tdd-4ycsb

###

你这样写是有问题的,LoginDialog.js 另外调用createApp,你ant组件只在main.js里面创建的app注册过。你应该使用app.defineComponent创建挂载组件

###
import { createVNode ,render} from 'vue'
    const body = document.body;
    const root = document.createElement("div");
    body.appendChild(root);
    root.className = "custom-root";
    export default {
        install(app){
            let div = document.createElement("div");
            root.appendChild(div);
            // com 为自己写的组件,  SoltChild 可以是自己的子组件 ,也可以不传
            let vm = createVNode(com,{},{
                // slots
                default:()=>createVNode(SoltChild)
            });
            vm.appContext = app._context; // 这句很关键,关联起了数据
            render(vm,div);
             
        }
    }

vm.appContext = app._context 加上这句,就没问题了

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • Vue3如何在挂载到全局的插件中使用第三

    Vue3如何在挂载到全局的插件中使用第三

  • 请大佬留下代码,下面是写的代码,但是

    请大佬留下代码,下面是写的代码,但是

  • PHP项目有没有 周期内调用频率控制限制

    PHP项目有没有 周期内调用频率控制限制

  • ts中声明一个变量时需要把他类型文件中

    ts中声明一个变量时需要把他类型文件中

腾讯云代理商
海外云服务器