Vue组件渲染时如何触发事件?
How to trigger event when Vue component is rendered?
我用谷歌搜索了很多,但没有找到任何相关信息。
我想在 Vue 渲染内容时淡入淡出。我的应用程序很大,需要一些时间才能为用户做好准备。但是当 Vue 将内容插入块时,CSS 动画不想工作。请参阅下面在 JSFiddle.
处列出的代码
HTML
<div id="my-app">
<p>Weeverfish round whitefish bass tarpon lighthousefish mullet tigerperch bangus knifefish coley Black sea bass tompot blenny madtom tapetail yellow-eye mullet..</p>
<hr>
<example></example>
</div>
CSS
#my-app {
opacity: 0;
transition: 2s;
}
#my-app.visible {
opacity: 1;
transition: 2s;
}
JavaScript
// Fade in animation will work if you comment this ...
Vue.component('example', {
template: `<p>Starry flounder loach catfish burma danio, three-toothed puffer hake skilfish spookfish New Zealand sand diver. Smooth dogfish longnose dace herring smelt goldfish zebra bullhead shark pipefish cow shark.</p>`
});
// ... and this
const app = new Vue({
el: '#my-app',
// Makes content visible, but don't provides fade-in animation
/*
created: function () {
$('#my-app').addClass('visible')
}
*/
});
// Makes content visible, but don't provides fade-in animation
// with enabled Vue
$('#my-app').addClass('visible');
// As you can see, animation with Vue works only here
setInterval(() => {
$('#my-app').toggleClass('visible');
}, 5000);
此外,在呈现 Vue 时,我没有找到 运行 代码的任何内置 Vue 解决方案(事件、方法等)。 load
& DOMContentLoaded
之类的事件也无济于事。 created
也没有提供预期结果:
const app = new Vue({
el: '#my-app',
// Makes content visible, but don't provides fade-in animation
created: function () {
$('#my-app').addClass('visible')
}
});
有人知道解决我的问题的好方法吗?
谢谢。
非常感谢@David L and @Bill Criswell for pointing to Transition Effects。我用这段代码达到了预期的结果:
HTML
<div id="my-app">
<app>
<p>Weeverfish round whitefish bass tarpon lighthousefish mullet tigerperch bangus knifefish coley Black sea bass tompot blenny madtom tapetail yellow-eye mullet..</p>
<hr>
<example></example>
</app>
</div>
CSS
.fade-enter-active, .fade-leave-active {
transition: opacity 1s
}
.fade-enter, .fade-leave-active {
opacity: 0
}
JavaScript
Vue.component('app', {
data: function () {
return {
show: false
}
},
mounted: function() {
this.show = true;
},
template: `<div>
<transition name="fade">
<div v-if="show">
<slot></slot>
</div>
</transition>
</div>`,
});
Vue.component('example', {
template: `<p>Starry flounder loach catfish burma danio, three-toothed puffer hake skilfish spookfish New Zealand sand diver. Smooth dogfish longnose dace herring smelt goldfish zebra bullhead shark pipefish cow shark.</p>`
});
const app = new Vue({
el: '#my-app',
});
这是 JSFiddle 的工作结果。
我用谷歌搜索了很多,但没有找到任何相关信息。
我想在 Vue 渲染内容时淡入淡出。我的应用程序很大,需要一些时间才能为用户做好准备。但是当 Vue 将内容插入块时,CSS 动画不想工作。请参阅下面在 JSFiddle.
处列出的代码HTML
<div id="my-app">
<p>Weeverfish round whitefish bass tarpon lighthousefish mullet tigerperch bangus knifefish coley Black sea bass tompot blenny madtom tapetail yellow-eye mullet..</p>
<hr>
<example></example>
</div>
CSS
#my-app {
opacity: 0;
transition: 2s;
}
#my-app.visible {
opacity: 1;
transition: 2s;
}
JavaScript
// Fade in animation will work if you comment this ...
Vue.component('example', {
template: `<p>Starry flounder loach catfish burma danio, three-toothed puffer hake skilfish spookfish New Zealand sand diver. Smooth dogfish longnose dace herring smelt goldfish zebra bullhead shark pipefish cow shark.</p>`
});
// ... and this
const app = new Vue({
el: '#my-app',
// Makes content visible, but don't provides fade-in animation
/*
created: function () {
$('#my-app').addClass('visible')
}
*/
});
// Makes content visible, but don't provides fade-in animation
// with enabled Vue
$('#my-app').addClass('visible');
// As you can see, animation with Vue works only here
setInterval(() => {
$('#my-app').toggleClass('visible');
}, 5000);
此外,在呈现 Vue 时,我没有找到 运行 代码的任何内置 Vue 解决方案(事件、方法等)。 load
& DOMContentLoaded
之类的事件也无济于事。 created
也没有提供预期结果:
const app = new Vue({
el: '#my-app',
// Makes content visible, but don't provides fade-in animation
created: function () {
$('#my-app').addClass('visible')
}
});
有人知道解决我的问题的好方法吗?
谢谢。
非常感谢@David L and @Bill Criswell for pointing to Transition Effects。我用这段代码达到了预期的结果:
HTML
<div id="my-app">
<app>
<p>Weeverfish round whitefish bass tarpon lighthousefish mullet tigerperch bangus knifefish coley Black sea bass tompot blenny madtom tapetail yellow-eye mullet..</p>
<hr>
<example></example>
</app>
</div>
CSS
.fade-enter-active, .fade-leave-active {
transition: opacity 1s
}
.fade-enter, .fade-leave-active {
opacity: 0
}
JavaScript
Vue.component('app', {
data: function () {
return {
show: false
}
},
mounted: function() {
this.show = true;
},
template: `<div>
<transition name="fade">
<div v-if="show">
<slot></slot>
</div>
</transition>
</div>`,
});
Vue.component('example', {
template: `<p>Starry flounder loach catfish burma danio, three-toothed puffer hake skilfish spookfish New Zealand sand diver. Smooth dogfish longnose dace herring smelt goldfish zebra bullhead shark pipefish cow shark.</p>`
});
const app = new Vue({
el: '#my-app',
});
这是 JSFiddle 的工作结果。