- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我为我的项目使用了 Vuetify.js
当我使用 v-dialog 组件时,我遇到了关闭 v-dialog 并再次打开的问题。
这是我的代码。<div @click="dialog=true">click here</div>
<v-dialog v-model="dialog">
<alert-popup />
</v-dialog>
data() {
return {
dialog : false
}
这是我第一次打开对话框时的工作,但是当我再次打开时只能看到不透明的黑色页面
最佳答案
您没有提供任何代码来重现该行为。但我猜你需要提供 <v-card>
对话框组件内的组件。如果你不提供它只是显示不透明度问题。放置 v-card
将消除不透明度问题。
<div id="app">
<v-app id="inspire">
<v-container>
<v-row justify="start">
<v-btn @click="openDialog">Open</v-btn>
<v-dialog v-model="dialog" max-width="300px">
<v-card>
<v-card-title>My Dialog</v-card-title>
<v-divider></v-divider>
<v-card-text>
This is text for dialog
</v-card-text>
<v-divider></v-divider>
<v-card-actions>
<v-btn x-small color="blue darken-1" text @click="dialog = false">Close</v-btn>
<v-btn x-small color="blue darken-1" text @click="dialog = false">Save</v-btn>
</v-card-actions>
</v-card>
</v-dialog>
</v-row>
</v-container>
</v-app>
</div>
这是
working code哪里有
v-card
内部组件
v-dialog
.
alert-popup
的自定义组件。内
v-dialog
.如果是这种情况,则需要对其进行一些重构以实现您正在寻找的内容。
<v-dialog>
. <alert-popup>
发出关闭事件组件,以便打开/关闭和单击打开不会导致问题。 <div id="app">
<v-app id="inspire">
<v-container>
<v-row justify="start">
<v-btn @click="openDialog">Open</v-btn>
<alert-popup :dialog="dialog" @close="closeMyDialog" />
</v-row>
</v-container>
</v-app>
</div>
Javascript:
let AlertPopup = Vue.component("AlertPopup", {
props: {
dialog: {
type: Boolean,
default: false
}
},
data: () => ({
open: false
}),
methods: {
close() {
this.open = false;
this.$emit("close");
}
},
watch: {
dialog(value) {
this.open = value;
}
},
created() {
this.open = this.dialog;
},
template: `
<v-dialog v-model="open" max-width="300px">
<v-card>
<v-card-title>My Dialog</v-card-title>
<v-divider></v-divider>
<v-card-text>
This is text for dialog
</v-card-text>
<v-divider></v-divider>
<v-card-actions>
<v-btn x-small color="blue darken-1" text @click="close">Close</v-btn>
</v-card-actions>
</v-card>
</v-dialog>
`
});
new Vue({
el: "#app",
vuetify: new Vuetify(),
components: {
AlertPopup
},
data: (vm) => ({
dialog: false
}),
computed: {},
methods: {
closeMyDialog() {
this.dialog = false;
},
openDialog() {
this.dialog = true;
}
}
});
如果看
AlertPopup
组件,它只需要一个名为 dialog 的 Prop ,我们可以从主组件传递,当按钮被点击时,它设置为 true,这会触发
AlertPopup
成分。
AlertPopup
组件,则模式对话框将不会在第二次之后打开。这种行为的原因是,当从父组件单击按钮时,会将对话框设置为 true 并将其传递给
AlertPopup
以及在
AlertPopup
内发生的任何事情留在该组件内和
dialog
父组件的属性永远不会改变。
close
事件,它不会第二次打开模态。
Update: It turns out we are unnecessary complicating things, we don'teven need to emit an event, we can pass in the close function as aprop and react to that, whenever the close button is clicked, it wouldcall the closeAlert().
<div id="app">
<v-app id="inspire">
<v-container>
<v-row justify="start">
<v-btn @click="openDialog">Open</v-btn>
<alert-popup :dialog="dialog" @close="closeMyDialog" :close="closeMyDialog" />
</v-row>
</v-container>
</v-app>
</div>
并且组件逻辑更新如下
let AlertPopup = Vue.component("AlertPopup", {
props: {
dialog: {
type: Boolean,
default: false
},
close: {
type: Function,
default: () => {}
}
},
data: () => ({
open: false
}),
methods: {
closeAlert() {
this.close();
}
},
template: `
<v-dialog v-model="dialog" max-width="300px" @click:outside="closeAlert">
<v-card>
<v-card-title>My Dialog</v-card-title>
<v-divider></v-divider>
<v-card-text>
This is text for dialog
</v-card-text>
<v-divider></v-divider>
<v-card-actions>
<v-btn x-small color="blue darken-1" text @click="closeAlert">Close</v-btn>
</v-card-actions>
</v-card>
</v-dialog>
`
});
new Vue({
el: "#app",
vuetify: new Vuetify(),
components: {
AlertPopup
},
data: (vm) => ({
dialog: false
}),
computed: {},
methods: {
closeMyDialog() {
debugger;
this.dialog = false;
},
openDialog() {
this.dialog = true;
}
}
});
最后这里是更新的
codepen
关于Vuetify.js:当我关闭并再次打开时,v-dialog 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63145526/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!