이 글에서는 주로 Laravel을 기반으로 한 사용자 동적 모듈 개발에 대한 관련 정보를 소개합니다. 이 글은 이를 따르는 모든 사람의 학습이나 업무에 대한 특정 참조 학습 가치를 가지고 있습니다. 아래 지침을 함께 배워보겠습니다. 그것이 모두에게 도움이 되기를 바랍니다.
머리말
거의 모든 커뮤니티 애플리케이션에 사용자 업데이트 섹션이 있다는 사실은 모두가 알고 있을 것입니다. 사용자는 친구 업데이트를 통해 더 흥미로운 콘텐츠를 얻을 수 있으므로 커뮤니티 활동과 사용자 충성도가 높아집니다. 구현은 주로 콘텐츠의 다양성에 반영되는 일반 콘텐츠 게시보다 상대적으로 더 복잡합니다.
이 문제를 해결하려면 이러한 다양한 유형의 콘텐츠를 추상화하고, 공통점을 추출하고, 동일한 구조를 사용하여 처리해야 하므로 개발이 훨씬 간단해집니다.
개념 추상
사용자 역학은 이름에서 알 수 있듯이 역학의 생성은 일련의 이벤트에 대한 역사적 기록이므로 먼저 "이벤트"라는 용어와 그것이 갖는 속성에 주의를 기울이십시오.
커뮤니티를 기반으로 한 트리거 거의 모든 이벤트는 사용자에 의해 트리거됩니다.
이벤트 본문, "xxx가 기사를 게시했습니다"의 "기사"와 같은 이벤트의 주요 정보입니다.
이벤트 속성, 이벤트 주제에 따라 이벤트 유형과 같은 다양한 추가 정보가 필요합니다.
발생 시간, 이벤트가 발생한 시간을 기록합니다. 물론 우리 데이터베이스는 일반적으로 모든 데이터가 생성되는 시간을 기록합니다.
우리는 구현하기 더 쉬운 4가지 기본 속성만 있는 구조로 사용자 역학을 추상화합니다.
- description 事件描述 - causer_id 或者 user_id 事件触发者 - subject_id 主体 ID - subject_type 主体类型 - properties 事件附加属性 - created_at 事件产生时间
주요 부분은 Laravel의 모프 관계, 다형성 연관입니다.
표시 방법
동적 디스플레이 요구 사항에는 일반적으로 다음이 포함됩니다.
내 친구의 역학
누군가의 역학, 일반적으로 개인 센터
모든 역학, 예를 들어 모두 Laravel China 홈페이지의 역학은
동적으로 검색하기가 비교적 드뭅니다
저는 현재 사용자 역학도 포함하는 EasyWeChat 웹사이트의 새 버전을 개발 중입니다. 예:
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)</code code> 이벤트 트리거 설정, 사용자 인스턴스 </p><ul class=" list-paddingleft-2"><li><p><code>withProperties($properties)
위 개념의 이벤트 속성 performedOn($model)
设置事件主体,也就是 Eloquent Model 实例
causedBy($user)
设置事件触发者, User 实例
withProperties($properties)
上面我们概念里的事件属性
withProperty($key, $value)
事件属性的单个用法
log($description)
withProperty($key, $value) </code >이벤트 속성의 단일 사용<p></p><p></p><code>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('发表了话题');
디스플레이 역학은 조건에 따라 데이터베이스에서 가져옵니다. 여기서는 패키지에서 제공하는 모델 클래스를 사용합니다: SpatieActivitylogModelsActivityuse SpatieActivitylogModelsActivity;
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
<?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('发表了话题'); } }
위에서 기록된 역학을 보면 ID만 저장되어 있다고 물을 수 있습니다. 이러한 종류의 다형성 연관은 쿼리할 때 매우 스트레스가 됩니다. 예를 들어, 우리는 역학을 다음과 같이 표시하려고 합니다.
An Xiaochao가 기사를 게시했습니다. 사용자 정의 메뉴 사용법》
기사의 ID와 유형만 저장하는 경우 표시할 제목을 가져오기 위해 기사 테이블도 한 번 쿼리해야 합니다. 실제로 수십 개의 SQL이 있을 수 있습니다. 네, 제가 해결한 방법은 다음과 같습니다.
사실 우리 사용자 역학은 100% 정확성을 요구하지 않는데, 녹음할 때 기사 제목을 저장하면 더 이상 표를 찾아볼 필요가 없나요? 실제로 제목 등 동적 목록에 표시해야 하는 주요 정보는 withProperties와 함께 저장되므로 단일 SQL로 동적 목록 문제가 해결됩니다.
이 접근 방식에도 단점이 있습니다. 예를 들어 기사 제목이 변경되면 동기화가 해제됩니다. 물론 기사가 수정될 때 이 속성을 변경할 수도 있지만 개인적으로는 필요하지 않다고 생각합니다. . 결국 그 당시의 상황을 기록하는 것이 역동성이고, 나중에 제목이 바뀌어도 문제가 없습니다.
알겠습니다. 사용자 동적 모듈의 개발이 여기에서 공유됩니다. 더 발전된 구현이 있다면 언제든지 연락주세요.
친구 동적 부분의 구현은 애플리케이션의 크기와 친구 관계 저장에 따라 다릅니다. 대부분은 친구 관계를 먼저 확인한 다음 관련 쿼리를 확인합니다. Bar를 직접 구현할 수도 있습니다.
관련 권장사항:
Laravel이 사전 로드를 통해 모델 쿼리를 최적화하는 방법에 대한 자세한 설명
Laravel에서 url()의 루트 주소 수정에 대한 자세한 설명
자세히 방법에 대한 설명 Laravel은 예약된 작업을 구현합니다
위 내용은 Laravel에서 사용자 동적 모듈 개발에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!