[TOC]
# 詳解
```
? creating - 對象已經 ready 但未寫入數據庫
? created - 對象已經寫入數據庫
? updating - 對象已經修改但未寫入數據庫
? updated - 修改已經寫入數據庫
? saving - 對象創建或者已更新但未寫入數據庫
? saved - 對象創建或者更新已經寫入數據庫
? deleting - 刪除前
? deleted - 刪除后
? restoring - 恢復軟刪除前
? restored - 恢復軟刪除后
```
依次是 saving>creating>created>saved。
update 同理就不具體貼代碼了, saving>updating>updated>saved。
而 delete 不涉及 save,因此依次只觸發了 deleting 和deleted。 當 restore 軟刪除記錄時觸發了 restoring 和 restored 方法。
Eloquent模型可以觸發事件,允許你在模型生命周期中的多個時間點調用如下這些方法:creating, created, updating, updated, saving, saved,deleting, deleted, restoring, restored。事件允許你在一個指定模型類每次保存或更新的時候執行代碼。
一個新模型被首次保存的時候,creating和created事件會被觸發。如果一個模型已經在數據庫中存在并調用save方法,updating/updated事件會被觸發,無論是創建還是更新,saving/saved事件都會被調用.
deleting和deleted很好理解,在刪除模型時觸發,deleting在刪除操作前執行,deleted在刪除完成后執行。
當創建模型時,依次執行saving、creating、created和saved,同理在更新模型時依次執行saving、updating、updated和saved。無論是使用批量賦值(create/update)還是直接調用save方法,都會觸發對應事件(前提是注冊了相應的模型事件)。
# 服務提供者寫
你可以在任何你喜歡的地方注冊模型事件,這里我們選擇在服務提供者AppServiceProvider的boot方法中注冊:
```
//注意命名空間
Post::saving(function($post){
echo 'saving event is fired<br>';
});
Post::creating(function($post){
echo 'creating event is fired<br>';
});
Post::created(function($post){
echo 'created event is fired<br>';
});
Post::saved(function($post){
echo 'saved event is fired<br>';
});
```
然后只有有對應的操作就會觸發這邊
# Tratis
核心就是trait里面有個boot+trait名,laravel在啟動的時候會檢測,并把他放在服務容器里面
用traits的話,用的時候use下就好了
比如在一個網站上用戶有活動記錄的,那么我們把他記錄下來
Activity表
| 鍵名 | 類型 |
| --- | --- |
| id | PK |
| user_id | FK posts's id |
| conversation_id | 多態關聯的主鍵id |
| conversation_type | 多態關聯的命名空間 |
| created_at | timestamp |
| updated_at | timestamp |
然后比如用戶新增一篇文章,我們要把他的行為記錄下來
寫個trait RecordActivity.php
```
namespace App\Models;
trait RecordActivity
{
/**
* 命名是boot+traits的名字
* 這樣寫laravel在啟動項目的時候會為我們自動執行這個方法
*/
public static function bootRecordActivity()
{
foreach (static::getModelEvents() as $event) {
static::$event(function ($model){
//生成相應數據,把數據寫到Activity這個表里面
$model->recordActivity();
});
}
}
protected static function getModelEvents()
{
//判斷用戶有沒有定義相關的屬性
if (isset(static::$recordEvents)){
return static::$recordEvents;
}
return ['created'];//你也可以加上其他的事件 比如updated
}
public function recordActivity()
{
Activity::create([
'user_id'=>1, //這邊測試就寫個1,可以寫\Auth::id()
'conversation_id'=>$this->id,
'conversation_type'=>get_class($this),
]);
}
}
```
一旦use這個trait,他會自動執行,一旦有created的事件發生(可以在里面自己定義)
自己定義就定義下這個屬性就好了 `static::$recordEvents` 他就不會用created了
Activity.php 活動模型
```
public function conversation()
{
return $this->morphTo();
}
```
User.php用戶模型
```
public function activities()
{
return $this->hasMany(Activity::class);
}
```
Post模型,讓post一旦有created就觸發寫好的
```
use RecordActivity;
```
我們開始試下
```
$post=\App\Models\Post::create(['title'=>'new1']);
return $post;
```
這樣我們可以看到Activities表中有活動記錄了
如果我們要查一個用戶的活動記錄
```
$user=\App\Models\User::find(1);
$activity=$user->activities->toArray();
return $activity;
```
我們就可以看到用戶在Activity表中的記錄了
如果我們要查一個用戶,我們可以在用戶表中寫對應的關聯
user.php中寫
```
public function activities()
{
//這邊的conversation就是activity模型的方法名
return $this->hasMany(Activity::class)->with('conversation');
}
```
然后我們測試下
```
$user=\App\Models\User::find(1);
$activity=$user->activities;
return $activity;
```
# 簡單粗魯(用于本地測試)
路由中定義:
~~~
Event::listen('eloquent.updated: App\Post',function (){
dump('測試一下修改事件');
});
Route::post('/post/{id}', 'PostController@update');
~~~
http://blog.csdn.net/a_new_steven/article/details/73604846
- 配置
- composer安裝
- composer用法
- composer版本約束表達
- phpstorm
- sftp文件同步
- php類型約束
- laradock
- 配置文件緩存詳解
- git
- 自定義函數
- 核心概念
- IOC
- 服務提供者
- Facade
- 契約
- 生命周期
- 路由
- 請求
- 命名路由
- 路由分組
- 資源路由
- 控制器路由
- 響應宏
- 響應
- Command
- 創建命令
- 定時任務
- console路由
- 執行用戶自定義的定時任務
- artisan命令
- 中間件
- 創建中間件
- 使用中間件
- 前置和后置
- 詳細介紹
- 訪問次數限制
- 為 VerifyCsrfToken 添加過濾條件
- 單點登錄
- 事件
- 創建
- ORM
- 簡介
- DB類
- 配置
- CURD
- queryScope和setAttribute
- 查看sql執行過程
- 關聯關系
- 一對一
- 一對多
- 多對多
- 遠程關聯
- 多態一對多
- 多態多對多
- 關聯數據庫的調用
- withDefault
- 跨模型更新時間戳
- withCount,withSum ,withAvg, withMax,withMin
- SQL常見操作
- 模型事件
- 模型事件詳解
- 模型事件與 Observer
- deleted 事件未被觸發
- model validation
- ORM/代碼片段
- Repository模式
- 多重where語句
- 中間表類型轉換
- Collection集合
- 新增的一些方法
- 常見用法
- 求和例子
- 機場登機例子
- 計算github活躍度
- 轉化評論格式
- 計算營業額
- 創建lookup數組
- 重新組織出表和字段關系并且字段排序
- 重構循環
- 其他例子
- 其他問題一
- 去重
- 第二個數組按第一個數組的鍵值排序
- 搜索ES
- 安裝
- 表單
- Request
- sessiom
- Response
- Input
- 表單驗證
- 簡介
- Validator
- Request類
- 接口中的表單驗證
- Lumen 中自定義表單驗證返回消息
- redis
- 廣播事件
- 發布訂閱
- 隊列
- 守護進程
- redis隊列的坑
- beanstalkd
- rabbitmq
- redis隊列
- 日志模塊
- 錯誤
- 日志詳解
- 數據填充與遷移
- 生成數據
- 數據填充seed
- migrate
- 常見錯誤
- Blade模板
- 流程控制
- 子視圖
- URL
- 代碼片段
- Carbon時間類
- 一些用法
- 郵件
- 分頁
- 加密解密
- 緩存
- 文件上傳
- 優化
- 隨記
- 嵌套評論
- 判斷字符串是否是合法的 json 字符串
- 單元測試
- 計算出兩個日期的diff
- 自定義一個類文件讓composer加載
- 時間加減
- 對象數組互轉方法
- 用戶停留過久自動退出登錄
- optional 輔助方法
- 文件下載
- Api
- Dingo api
- auth.basic
- api_token
- Jwt-Auth
- passport
- Auth
- Authentication 和 Authorization
- Auth Facade
- 授權策略
- Gates
- composer包
- debug包
- idehelp包
- image處理
- 驗證碼
- jq插件
- 第三方登錄
- 第三方支付
- log顯示包
- 微信包
- xss過濾
- Excel包
- MongoDB
- php操作
- 聚合查詢
- 發送帶附件郵件
- 中文轉拼音包
- clockwork網頁調試
- emoji表情
- symfony組件
- swooletw/laravel-swoole
- 常見問題
- 跨域問題
- Laravel隊列優先級的一個坑
- cache:clear清除緩存問題
- .env無法讀取
- 源碼相關基礎知識
- __set和__get
- 依賴注入、控制反轉和依賴倒置原則
- 控制反轉容器(Ioc Container)
- 深入服務容器
- call_user_func
- compact
- 中間件簡易實現
- array_reduce
- 中間件實現代碼
- Pipeline管道操作
- composer自動加載
- redis延時隊列
- 了解laravel redis隊列
- cli
- 源碼解讀
- Facade分析
- Facade源碼分析
- IOC服務容器
- 中間件原理
- 依賴注入淺析
- 微信
- 微信公眾號
- 常用接收消息
- 6大接收接口
- 常用被動回復消息
- 接口調用憑證
- 自定義菜單
- 新增素材
- 客服消息
- 二維碼
- 微信語音
- LBS定位
- 網頁授權
- JSSDK
- easywechat
- 小程序
- 小程序配置app.json