gpt4 book ai didi

javascript - 如何在 Vue.js 中有条件地渲染元素?

转载 作者:行者123 更新时间:2023-12-01 03:24:12 25 4
gpt4 key购买 nike

我是 Vue.js 新手,我刚刚在这里阅读了有关条件渲染的文档 ( https://v2.vuejs.org/v2/guide/conditional.html ),但不知何故无法让它工作......

我的代码:

<button onclick="showTemplate()">Teste</button>


<template v-if="app">

<div id="app">
{{ message }}
</div>

</template>

function showTemplate(){
var app = new Vue({
el: '#app',
data: {
message: 'Hello Vue!'
}
})
}

我希望模板标记仅在应用程序实例化后呈现。我也尝试过此代码的变体,但没有成功。有人可以帮忙吗?

最佳答案

使用v-cloakv-cloak 的预期用途是隐藏 Vue,直到实例化为止。

function showTemplate() {
var app = new Vue({
el: '#app',
data: {
message: 'Hello Vue!'
}
})
}
[v-cloak] {
display: none;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.3.4/vue.js"></script>
<button onclick="showTemplate()">Teste</button>

<div id="app" v-cloak>
{{ message }}
</div>

以下是在检索数据时隐藏“正在加载”屏幕的方法。在这种情况下,该按钮将用作我们的加载屏幕。

var app = new Vue({
el: '#app',
data: {
message: 'Hello Vue!',
loaded: false
},
methods: {
getData() {
setTimeout(() => this.loaded = true, 2000)
}
}
})
[v-cloak] {
display: none;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.3.4/vue.js"></script>

<div id="app" v-cloak>
<button v-if="!loaded" @click="getData">Get Data</button>

<div v-if="loaded">
{{ message }}
</div>
</div>

关于javascript - 如何在 Vue.js 中有条件地渲染元素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44951839/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com