Laravel開発ユーザーダイナミックモジュールの詳細説明
この記事では、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 ...
ログイン後にコピー 基本的に次のことがわかります。すべてのダイナミクスは同じ方法で記述されますが、異なるため、「フォロー」、「公開」、「返信」、「購入」などの「イベント タイプ」も記録する必要があります。
その後、ブレードまたは他のテンプレート エンジンを使用するときに、ケースの記述を切り替えて、これらのスタイルをレンダリングする別のテンプレートを適用できます。たとえば、ブレードでは、次のようになります:
@switch($activity->properties['event'] ?? '') @case('discussion.created') ... @break @case('comment.created') ... @break @endswitch
コード実装
データの保存と表示の設計とその実装方法については以前に説明しましたが、さらに熱心であれば、それを実装するためのコードを記述するだけで、それをネイティブに実装できます。今日お勧めしたいこと spatie/laravel-activitylogを使って実装しています: インストールはいつも簡単ですよね:
$ composer install spatie/laravel-activitylog -vvv
ダイナミクスの記録
activity()->log('Look, I logged something');
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'
performedOn($model)
Eloquent Model インスタンスであるイベント本体を設定します
causedBy($user)</code code> イベント トリガー、ユーザー インスタンスを設定します <p><code>performedOn($model)
设置事件主体,也就是 Eloquent Model 实例causedBy($user)
设置事件触发者, User 实例withProperties($properties)
上面我们概念里的事件属性withProperty($key, $value)
事件属性的单个用法log($description)
withProperties($properties)
上記の概念におけるイベント プロパティ withProperty($key, $value) </code >イベント属性の単一使用</p><p></p><p><code>log($description)
イベントの説明たとえば、記事を記録したいとします。ユーザーがディスカッションを投稿しました:
$discussion = App\Discussion::create([...]); activity()->on($discussion) ->withProperty('event', 'discussion.created') ->log('发表了话题');
または、ユーザーが登録するときに、更新を記録してください:
activity()->on($user) ->withProperty('event', 'user.created') ->log('加入 EasyWeChat');
このモジュールにトリガーを設定しない場合、デフォルトでトリガーが設定されていないことがわかります。現在ログインしているユーザー。
ディスプレイダイナミクスディスプレイダイナミクスは、条件に従ってデータベースから取得されます。ここでは、パッケージによって提供されるモデルクラスを使用します: SpatieActivitylogModelsActivity
use SpatieActivitylogModelsActivity;
// 全部动态 $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
<?php
namespace App\Listeners;
class UserActivitySubscriber
{
protected $lisen = [
'eloquent.created: App\User' => 'onUserCreated',
'eloquent.created: App\Discussion' => 'onDiscussionCreated',
];
public function subscribe($events)
{
foreach ($this->lisen as $event => $listener) {
$events->lisen($event, __CLASS__.'@'.$listener);
}
}
public function onUserCreated($user)
{
activity()->on($user)
->withProperty('event', 'user.created')
->log('加入 EasyWeChat');
}
public function onDiscussionCreated($discussion)
{
activity()->on($discussion)
->withProperty('event', 'discussion.created')->log('发表了话题');
}
}
/** * @var array */ protected $subscribe = [ \App\Listeners\UserActivitySubscriber::class, ];
上記の記録されたダイナミクスを見ると、ID のみが保存されているのではないかと疑問に思うかもしれません。たとえば、クエリを実行するときに、ダイナミクスを次のように表示したいとします。カスタムメニューの使い方》
記事のIDとタイプを保存するだけの場合、表示するタイトルを取得するために記事テーブルを一度クエリする必要もあります。そのような動的リストの場合、実際には数十のSQLが存在する可能性があります。はい、私の解決策は次のとおりです:
実際、ユーザー ダイナミクスは 100% の精度を必要としません。そのため、記録時に記事のタイトルを保存すれば、テーブルを参照する必要はなくなりますか?実際、タイトルなど、動的リストに表示する必要がある重要な情報は withProperties と一緒に保存されるため、単一の SQL で動的リストの問題が解決されます。
このアプローチには欠点もあります。たとえば、記事のタイトルが変更されると、同期が失われます。もちろん、記事を修正したときにこの属性を変更することもできますが、個人的には必要ないと思います。 。結局のところ、その時の状況を記録するのがダイナミックであり、後からタイトルが変更されても問題ありません。
OK、ユーザー動的モジュールの開発はここで共有されます。より高度な実装がある場合は、お気軽にご連絡ください。
フレンドの動的部分の実装については、アプリケーションのサイズとフレンド関係のストレージによって異なりますが、ほとんどの場合、最初にフレンド関係を確認してから、関連するクエリを確認することができます。バーを自分で実装することもできます。
関連する推奨事項:
Laravel がプリロードを通じてモデルクエリを最適化する方法の詳細な説明
Laravel の url() のルートアドレス変更の詳細な説明
詳しいやり方説明Laravel はスケジュールされたタスクを実装します
以上がLaravel開発ユーザーダイナミックモジュールの詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Laravelの電子メールの送信が失敗したときに戻りコードを取得する方法。 Laravelを使用してアプリケーションを開発する場合、検証コードを送信する必要がある状況に遭遇することがよくあります。そして実際には...

LaravelスケジュールタスクRAN RANSPONSIVEトラブルシューティングRALAVELのスケジュールタスクスケジューリングを使用すると、多くの開発者がこの問題に遭遇します。スケジュール:実行...

Laravelの電子メールの検証コードの送信の障害を処理する方法は、Laravelを使用することです...

DCATを使用するときにDCATADMIN(Laravel-Admin)にデータを追加するためにカスタムクリックのテーブル関数を実装する方法...

Laravel FrameworkでRedis接続の共有の影響とLaravelフレームワークとRedisを使用する際のメソッドを選択すると、開発者は問題に遭遇する可能性があります。

Laravel Multi-Tenant拡張機能パッケージStancl/Tenancyのカスタムテナントデータベース接続Laravel Multi-Tenant ExtensionパッケージStancl/Tenancyを使用したマルチテナントアプリケーションを構築する際の...

LaravelEloquentモデルの検索:データベースデータを簡単に取得するEloquentormは、データベースを操作するための簡潔で理解しやすい方法を提供します。この記事では、さまざまな雄弁なモデル検索手法を詳細に紹介して、データベースからのデータを効率的に取得するのに役立ちます。 1.すべてのレコードを取得します。 ALL()メソッドを使用して、データベーステーブルですべてのレコードを取得します:useapp \ models \ post; $ post = post :: all();これにより、コレクションが返されます。 Foreach Loopまたはその他の収集方法を使用してデータにアクセスできます。

700万のレコードを効率的に処理し、地理空間技術を使用したインタラクティブマップを作成します。この記事では、LaravelとMySQLを使用して700万を超えるレコードを効率的に処理し、それらをインタラクティブなマップの視覚化に変換する方法について説明します。最初の課題プロジェクトの要件:MySQLデータベースに700万のレコードを使用して貴重な洞察を抽出します。多くの人は最初に言語をプログラミングすることを検討しますが、データベース自体を無視します。ニーズを満たすことができますか?データ移行または構造調整は必要ですか? MySQLはこのような大きなデータ負荷に耐えることができますか?予備分析:キーフィルターとプロパティを特定する必要があります。分析後、ソリューションに関連している属性はわずかであることがわかりました。フィルターの実現可能性を確認し、検索を最適化するためにいくつかの制限を設定しました。都市に基づくマップ検索
