この記事では主に、Laravel に基づくユーザー動的モジュールの開発に関する関連情報をサンプルコードを通じて詳しく紹介します。この記事は、学習や仕事に必要な学習に役立ちます。以下に来て私と一緒に学びましょう。
前書き
ほぼすべてのコミュニティ アプリケーションにユーザー更新セクションがあり、ユーザーは友達の更新を通じてより興味深いコンテンツを入手できるため、コミュニティのアクティビティとユーザーの定着率が向上することは誰もが知っていると思います。その実装は通常のコンテンツ発行よりも比較的複雑であり、主にコンテンツの多様性に反映されています。
この問題を解決するには、これらの異なるタイプのコンテンツを抽象化し、共通点を抽出し、同じ構造を使用してそれらを処理する必要があります。これにより、開発がはるかに簡単になります。
概念の要約
ユーザーダイナミクス、その名前が示すように、ダイナミクスの生成は一連のイベントの歴史的記録であるため、まず「イベント」という用語とそれがどのような属性を持っているかに注意してください:
コミュニティに基づくトリガー ほとんどすべてのイベントはユーザーによってトリガーされます
イベント本体、「xxx 記事が公開されました」の「記事」など、イベントの主な情報。
イベントの属性、イベントの主題が異なると、イベントの種類など、異なる追加情報が必要になります。
発生時間、イベントが発生した時間を記録します。通常、データベースにはすべてのデータが生成された時間が記録されます。
ユーザーのダイナミクスを 4 つの基本属性のみを持つ構造に抽象化します。これは実装が簡単です:
- description 事件描述 - causer_id 或者 user_id 事件触发者 - subject_id 主体 ID - subject_type 主体类型 - properties 事件附加属性 - created_at 事件产生时间
主要な部分は、Laravel のモーフ関係、ポリモーフィック関係です。
表示方法
私たちの動的表示ニーズには通常次のものが含まれます:
友達のダイナミクス
誰かのダイナミクス、通常は個人の中心
すべてのダイナミクス、たとえば、すべてLaravel China ホームページのダイナミクス
ダイナミック検索は比較的まれです
私は現在、ユーザー ダイナミクスも備えた EasyWeChat Web サイトの新しいバージョンを開発中です。例:
xxx 发布了讨论 《请问大家怎么使用 xxx》 xxx 评论了 xxx 的话题 《请问大家怎么使用 xxx》 xxx 回复了 xxx 的评论 “我是按照文档上 ...” xxx 购买了 《微信开发:自定义菜单的使用》 xxx 关注了 xxx ...
基本的にあらゆる種類のダイナミクスの書き方が異なるため、「フォロー」、「公開」、「返信」、「購入」などの「イベントの種類」も記録する必要があります。
その後、ブレードまたは他のテンプレート エンジンを使用するときに、ケースの記述を切り替えて、これらのスタイルをレンダリングする別のテンプレートを適用できます。たとえば、ブレードでは、次のようになります。
データの保存と表示の設計とその実装方法については以前に説明しましたが、もっと熱心であれば、上記の実装方法は明確に説明されています。今日はそれを実装します。推奨されるのは、spatie/laravel-activitylog を使用して次のことを実現することです:
@switch($activity->properties['event'] ?? '')
@case('discussion.created')
...
@break
@case('comment.created')
...
@break
@endswitch
$ composer install spatie/laravel-activitylog -vvv
activity()->log('Look, I logged something');
メソッドの紹介:
performedOn($model)
イベント本体を設定します。これが Eloquent Model インスタンスです
causedBy($user)
イベント トリガー、ユーザー インスタンスを設定します
withProperties($properties)
上記のコンセプトperformedOn($model)
设置事件主体,也就是 Eloquent Model 实例
causedBy($user)
设置事件触发者, User 实例
withProperties($properties)
上面我们概念里的事件属性
withProperty($key, $value)
事件属性的单个用法
log($description)
withProperty($key, $value)
イベント属性の単一使用log($description)
イベントの説明
activity() ->performedOn($anEloquentModel) ->causedBy($user) ->withProperties(['customProperty' => 'customValue']) ->log('Look, I logged something'); $lastLoggedActivity = Activity::all()->last(); $lastLoggedActivity->subject; //returns an instance of an eloquent model $lastLoggedActivity->causer; //returns an instance of your user model $lastLoggedActivity->getExtraProperty('customProperty'); //returns 'customValue' $lastLoggedActivity->description; //returns 'Look, I logged something'
$discussion = App\Discussion::create([...]);
activity()->on($discussion)
->withProperty('event', 'discussion.created')
->log('发表了话题');
ダイナミクスの表示
activity()->on($user)
->withProperty('event', 'user.created')
->log('加入 EasyWeChat');
ある程度の経験とスキル
// 全部动态 $activities = Activity::all(); // 用户 ID 为 2 的动态 $activities = Activity::causedBy(User::find(2))->paginate(15); // 以文章 ID 为 13 为主体的动态 $activities = Activity::forSubject(Post::find(13))->paginate(15);
$ ./artisan make:listener UserActivitySubscriber
/** * @var array */ protected $subscribe = [ \App\Listeners\UserActivitySubscriber::class, ];
上面我们利用了 Eloquent 模型事件来监听模型的变化,当各种模型事件创建的时候我们调用对应的方法来记录动态,所以实现起来非常的方便。
在事件属性里记录关键信息
看到上面记录动态的时候你可能会问,只存储了 ID,这种多态关联,查询的时候会压力很大,比如,我们要将动态显示为:
安小超 发布了文章 《自定义菜单的使用》
我们如果只是存储了文章的 id 与类型,我们还需要查询一次文章表,才能得到标题用于显示,这样一个动态列表的话,可能会几十条 SQL 了,的确是这样的,我的解决方案是这样的:
其实我们的用户动态是不要求 100% 精准的,所以,我如果在记录时把文章的标题一起存下来是不是就不用再查表了?其实就是,我们在动态列表需要展示的关键信息,比如标题这些一起用 withProperties 存起来,这样就一条 SQL 解决了动态列表问题。
这样的做法也有弊端,比如文章改了标题的时候,这里就不同步了,当然你也可以在文章修改时来改这个属性,不过我个人认为没有多大必要。毕竟动态就是记录了当时的情况,后来改标题了并没有什么问题。
OK,用户动态模块的开发就分享到这里,如果你有更高级的实现欢迎随时交流。
关于好友动态部分的实现,根据你的应用量级,以及好友关系的存储各有不同,大家自己集思广益即可,大部分都是先查好友关系再查动态,关联查询也可以,自己实现吧。
总结
以上がLaravelによるユーザー動的モジュール開発実装例の共有の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。