Я делаю систему корзины покупок с 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;
}
(И да, я добавлю это в следующий раз).
Это работает отлично, и появляется сообщение. Тем не менее, я хочу, чтобы сообщение исчезло через некоторое время, скажем несколько секунд. Как я могу это сделать с Vue? Я пробовал setTimeOut
, но Vue, похоже, не нравится, говоря undefined.
РЕДАКТИРОВАТЬ: Я искал setTimeOut
как идиот. Однако он все еще не работает:
Теперь моя функция:
addToBasket: function(){
item = this.photo;
this.$http.post('/api/buy/addToBasket', item);
this.basketAddSuccess = true;
setTimeout(function(){
this.basketAddSuccess = false;
}, 2000);
}