Saya sedang mengusahakan sistem suka/tidak suka pada Laravel/VueJS.
Sistem saya berfungsi, tetapi saya mahu mengelakkan spammer.
Butang suka:
<a v-on:click="like(10, $event)"> <i class="fas fa-heart"></i> </a>
10 ialah id pos, ia dijana dalam laravel Blade...
Ini adalah cara saya cuba mengelakkan spammer:
const app = new Vue({ el: '#app', data() { return { allowed: true, }; }, methods: { like: function (id, event) { if (this.allowed) { axios.post('/posts/' + id + '/like', { post_id: id, }) .then((response) => { this.allowed = false; //Set allowed to false, to avoid spammers. ..... code which changes fa-heart, changes class names, texts etc .... // send notification to user Vue.toasted.show('Bla bla bla successfuly liked post', { duration: 2000, onComplete: (function () { this.allowed = true //After notification ended, user gets permission to like/dislike again. }) });
Tetapi ada sesuatu yang hilang di sini, atau saya melakukan sesuatu yang salah. Apabila saya mengklik pada ikon yang serupa dengan sangat cepat dan menyemak permintaan, axios menghantar 3-4-5 permintaan (bergantung pada kelajuan anda mengklik)
Hanya selepas 3-5 permintaan data.allowed
才会变成 false
. kenapa? Saya mahu:
this.allowed = false;
akan terus dipanggil sehingga panggilan API selesai, membolehkan anda menghantar lebih banyak spam pada masa ini. Sahkanif(this.allowed)
后立即将其设置为false
.