Sto creando un sistema di carrello con Laravel e Vue. Quando aggiungo un elemento al carrello, visualizzo un messaggio di conferma commutando una variabile Vue osservata da un v-se:Vue equivalente di setTimeOut?
<div class="alert alert-success" v-if="basketAddSuccess" transition="expand">Added to the basket</div>
E il JS:
addToBasket: function(){
item = this.product;
this.$http.post('/api/buy/addToBasket', item);
this.basketAddSuccess = true;
}
(E sì, io aggiungerà questo in un catch quindi a breve).
Questo funziona correttamente e viene visualizzato il messaggio. Tuttavia, mi piacerebbe che il messaggio scomparisse di nuovo dopo un certo tempo, diciamo alcuni secondi. Come posso farlo con Vue? Ho provato setTimeOut
ma a Vue sembra non piacergli, dicendo che non è definito.
EDIT: Stavo scrivendo in modo errato setTimeout
come un idiota. Tuttavia, ancora non funziona:
La mia funzione è ora:
addToBasket: function(){
item = this.photo;
this.$http.post('/api/buy/addToBasket', item);
this.basketAddSuccess = true;
setTimeout(function(){
this.basketAddSuccess = false;
}, 2000);
}
prova 'setTimeout (() => { this.basketAddSuccess = false; }, 2000); ' –
Probabilmente,' questo' all'interno di 'setTimeout' non fa riferimento all'oggetto principale. – akinuri
@alexanderfarkas funziona, grazie! – flurpleplurple