duanquanzhi5560 2019-01-18 12:25
浏览 183
已采纳

将单个Laravel通知标记为已读

I have a page in my application that displays a list of all of the notifications a user currently has that are unread and each notification will have a read icon.

The ID in the database is set to char so is a long string of letters and numbers. When I display the id of the notifications on the page, they all return numbers that in no way relate to what is in the database so when I run a query to read a notification, it can't find the ID because the ID isn't matching.

What is the best method to read a single notification in Laravel? I'm using the code below to try, but it's the $request->get('id') that's incorrect as I seem to get 12310 as an ID and even 0 for some of them.

Auth::user()->unreadNotifications->where('id', $request->get('id'))->markAsRead()
  • 写回答

2条回答 默认 最新

  • dongxuan2577 2019-01-18 16:42
    关注

    Laravel notifications table's id use CHAR as the default field type. So, when you filter for certain id you have to use first() like the following. Since the unreadNotifications is the Illuminate\Notifications\DatabaseNotificationCollection

    $notificationId = request('notification_id');
    
    $userUnreadNotification = auth()->user()
                                ->unreadNotifications
                                ->where('id', $notificationId)
                                ->first();
    
    if($userUnreadNotification) {
        $userUnreadNotification->markAsRead();
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入
  • ¥40 使用MATLAB解答线性代数问题
  • ¥15 COCOS的问题COCOS的问题
  • ¥15 FPGA-SRIO初始化失败
  • ¥15 MapReduce实现倒排索引失败
  • ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
  • ¥15 找一位技术过硬的游戏pj程序员
  • ¥15 matlab生成电测深三层曲线模型代码
  • ¥50 随机森林与房贷信用风险模型