vue组件组件层级弹出框dialog显示问题

Element 使用dialog框是内容框和遮罩层的层级不对

 出现这种情况只要在弹出框架的属性上加上 append-to-body

 完美解决。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在JS中调用Vue组件显示dialog,同样可以先创建一个全局的dialog组件,然后在需要显示dialog的地方调用该组件。 下面是实现的步骤: 1. 创建全局的dialog组件Vue实例的components属性中注册一个全局的dialog组件,并在模板中显示需要展示的内容。 ```js Vue.component('dialog', { props: { title: String, content: String }, template: ` <div class="dialog"> <div class="dialog__header">{{title}}</div> <div class="dialog__content">{{content}}</div> </div> ` }); ``` 在上面的代码中,我们创建了一个名为dialog组件,该组件接收两个props:title和content,分别表示dialog的标题和内容。在模板中,我们通过插值表达式将这两个props渲染到页面上。 2. 在需要显示dialog的地方调用该组件 在需要显示dialog的地方,可以通过Vue实例的$mount方法创建一个新的Vue实例,并将dialog组件作为选项传递给该实例的components属性。然后,将该实例的$el属性插入到DOM中,显示dialog组件。 ```js function showDialog(title, content) { let dialogInstance = new Vue({ el: document.createElement('div'), components: { 'dialog': Vue.component('dialog') }, template: '<dialog :title="title" :content="content"></dialog>', data: { title, content } }); document.body.appendChild(dialogInstance.$el); } ``` 在上面的代码中,我们创建了一个名为showDialog的函数,用于显示dialog组件。该函数通过创建一个新的Vue实例来显示dialog组件,并将该实例的$el属性插入到DOM中。在模板中,我们通过绑定数据的方式将传入的title和content渲染到页面上。 3. 隐藏dialog组件 在需要隐藏dialog的地方,可以通过销毁dialog实例来隐藏dialog组件。 ```js function hideDialog() { let dialogEl = document.querySelector('.dialog'); if (dialogEl) { dialogEl.parentNode.removeChild(dialogEl); } } ``` 在上面的代码中,我们创建了一个名为hideDialog的函数,用于隐藏dialog组件。该函数通过查询DOM中是否存在dialog元素,如果存在则删除该元素,从而隐藏dialog组件。 综上所述,我们可以通过创建全局的dialog组件,并在需要显示dialog的地方调用该组件显示dialog。同时,可以通过销毁dialog实例来隐藏dialog组件

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值