我在用 Laravel 和 Vue 做一个购物车系统。当我向篮子中添加一个条目时,我通过切换一个 Vue 变量来显示一条确认消息,这个变量被 v-if 监视:
<div class="alert alert-success" v-if="basketAddSuccess" transition="expand">Added to the basket</div>
还有 JS:
addToBasket: function(){
item = this.product;
this.$http.post('/api/buy/addToBasket', item);
this.basketAddSuccess = true;
}
(是的,我很快会在 then-catch 中添加这个)。
这可以正常工作,并显示消息。然而,我希望消息在一定时间后再次消失,比如说几秒钟。我怎么能和 Vue 一起做这个?我试过 setTimeOut,但 Vue 似乎不喜欢它,说它是未定义的。
编辑: 我像个白痴一样拼错了 setTimeout。然而,它仍然不起作用:
我现在的职责是:
addToBasket: function(){
item = this.photo;
this.$http.post('/api/buy/addToBasket', item);
this.basketAddSuccess = true;
setTimeout(function(){
this.basketAddSuccess = false;
}, 2000);
}