У меня проблема. Я использую толкатель для уведомления в реальном времени, и когда он запускается, он уведомляет меня об использовании noty, , но я также хочу, чтобы он показывал номер нового уведомления в режиме реального времени в моем представлении, аналогичном facebook.В реальном времени Получение данных с laravel5.2, vue.js и толкателем
<span class="label label-warning" v-show="new_count">@{{ new_count }}<!-- get the new notifications --></span>
Как это сделать?
это мои коды.
nav.js
new Vue({
el: '#nav',
data: {
new_count: 0
},
methods: {
getNewCount: function() {
this.$http.get('cron', function(new_count){
console.log(new_count);
this.new_count = new_count;
}.bind(this));
}
}
});
Крон контроллер Работа. этот метод запускается каждую минуту.
class CronJobController extends Controller
{
public function getIndex()
{
$old_fail_notification = FailNotification::where('seen', 0)->count();
$subjects_with_fail = Grade::where('grade', 'F')->groupBy('subject_id')->orderBy('subject_id', 'ASC')->get();
return response()->json(['new_count' => 2]); //send this to navbar
foreach ($subjects_with_fail as $subject) {
$subject_to_check = Grade::where('grade', 'F')->where('subject_id', $subject->subject_id)->where('reviewed', '0')->get(); //add if grade is IC or D
if (count($subject_to_check) >= 3) {
$failed = new FailNotification();
$failed->message = '[subject-'.$subject->subject_id.'] can now be opened.';
$failed->save();
foreach ($subject_to_check as $subject) {
$subject = Grade::find($subject->id);
$subject->reviewed = 1;
$subject->save();
}
}
}
$fail_notification = FailNotification::all()->count();
//UPDATE NOTIFICATION COUNT HERE REAL TIME USING AJAX
if ($fail_notification > $old_fail_notification) {
$new_notification_count = $fail_notification - $old_fail_notification;
Pusher::trigger('test-channel', 'test-event', [
'name' => 'You have a new',
'message' => 'Notification'
]);
Pusher::trigger('navbar-channel', 'navbar-event', [
'new_notif_count' => $new_notification_count,
]);
return response()->json(['new_count' => $new_notification_count]); //send this to navbar
}
}
}
, пожалуйста, что я делаю неправильно и как это делать правильно.
И где вы подписавшись на услуга толкателя? как сказано ниже, метод get из vue.resource - это единственный метод, и вам нужно постоянно слушать события-толкатели. В документах говорится, что вы делаете это с помощью метода susbcirbe? где это в коде Vue? –
спасибо! Сейчас я изучаю подписку на услугу толкача. –