我正在用Laravel和Vue制作购物车系统。当我将项目添加到购物篮,我显示通过切换一个Vue的变量的确认消息通过正在观看的V-如果:等价于setTimeOut的Vue?
<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;
}
(是的,我稍后将会加入这个)。
这工作正常,消息出现。但是,我希望消息在一段时间后再次消失,比如几秒钟。我如何用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);
}
试'的setTimeout(()=> { this.basketAddSuccess = FALSE; },2000);' –
''setTimeout'内部的'this'可能不是指主对象。 – akinuri
@alexanderfarkas这个作品,谢谢! – flurpleplurple