文章轉發自專業的Laravel開發者社群,原始連結:learnku.com/laravel/t/2…
Laravel Eloquent 通常返回一個集合作為結果,集合包含很多有用的、功能強大的方法。你可以很方便的對集合進行過濾、修改等操作。本次教程就一起來看一看集合的常用方法及功能。
集合並不僅限於 eloquent ,也可以單獨使用。但 Eloquent 的結果就是一個集合。你可以使用助手函式 collect
將陣列轉化為集合。下面所列出的集合的方法適用於 eloquent 結果的同時也適用於集合本身。
比方說,你有一個帖子模型。 你找到所有 php
類別的帖子。
$posts = App\Post::where('category', 'php')->get();
複製程式碼
上面的命令返回一個集合。 集合是一個laravel類,它在內部使用陣列函式併為它們新增許多功能。
你可以簡單的使用 collect
方法建立一個集合,如下:
$collection = collect([
[
'user_id' => '1',
'title' => 'Helpers in Laravel',
'content' => 'Create custom helpers in Laravel',
'category' => 'php'
],
[
'user_id' => '2',
'title' => 'Testing in Laravel',
'content' => 'Testing File Uploads in Laravel',
'category' => 'php'
],
[
'user_id' => '3',
'title' => 'Telegram Bot',
'content' => 'Crypto Telegram Bot in Laravel',
'category' => 'php'
],
]);
複製程式碼
上面的陣列實際上是 Post 模型的值。 在本教程中,我們將使用此陣列進行簡化。 請記住,一切都將以同樣的方式基於 eloquent。
當我們在 eloquent 集合上使用輔助方法時,不會再查詢資料庫。 我們首先要從資料庫中獲取所有結果,然後我們使用集合方法來過濾和修改它們,而無需查詢資料庫。
filter()
filter,最有用的 laravel 集合方法之一,允許您使用回撥過濾集合。 它只傳遞那些返回true的項。 所有其他專案都被刪除。 filter
返回一個新例項而不更改原始例項。 它接受 value
和 key
作為回撥中的兩個引數。
$filter = $collection->filter(function($value, $key) {
if ($value['user_id'] == 2) {
return true;
}
});
$filter->all();
複製程式碼
all
方法返回底層陣列。 上面的程式碼返回以下響應。
[
1 => [
"user_id" => 2,
"title" => "Testing in Laravel",
"content" => "Testing File Uploads in Laravel",
"category" => "php"
]
]
複製程式碼
search()
search
方法可以用給定的值查詢集合。如果這個值在集合中,會返回對應的鍵。如果沒有資料項匹配對應的值,會返回 false
。
$names = collect(['Alex', 'John', 'Jason', 'Martyn', 'Hanlin']);
$names->search('Jason');
// 2
複製程式碼
search
方法預設使用鬆散比較。你可以在它的第二個引數傳 true
使用嚴格比較。
你也可以傳你自己的回撥函式到 search
方法中。將返回通過回撥真值測試的第一個項的鍵。
$names = collect(['Alex', 'John', 'Jason', 'Martyn', 'Hanlin']);
$names->search(function($value, $key) {
return strlen($value) == 6;
});
// 3
複製程式碼
chunk()
chunk
方法將集合分割為多個給定大小的較小集合。將集合顯示到網格中非常有用。
$prices = collect([18, 23, 65, 36, 97, 43, 81]);
$prices = $prices->chunk(3);
$prices->toArray();
複製程式碼
以上程式碼生成效果。
[
0 => [
0 => 18,
1 => 23,
2 => 65
],
1 => [
3 => 36,
4 => 97,
5 => 43
],
2 => [
6 => 81
]
]
複製程式碼
dump()
dump
列印集合的方法。 它可用於在任何位置的除錯和查詢集合內的內容。
$collection->whereIn('user_id', [1, 2])
->dump()
->where('user_id', 1);
複製程式碼
dump
上述程式碼結果。
map()
map
方法用於遍歷整個集合。 它接受回撥作為引數。 value
和 key
被傳遞給回撥。 回撥可以修改值並返回它們。 最後,返回修改項的新集合例項。
$changed = $collection->map(function ($value, $key) {
$value['user_id'] += 1;
return $value;
});
return $changed->all();
複製程式碼
基本上,它將 user_id
增加1。
上面程式碼的響應如下所示。
[
[
"user_id" => 2,
"title" => "Helpers in Laravel",
"content" => "Create custom helpers in Laravel",
"category" => "php"
],
[
"user_id" => 3,
"title" => "Testing in Laravel",
"content" => "Testing File Uploads in Laravel",
"category" => "php"
],
[
"user_id" => 4,
"title" => "Telegram Bot",
"content" => "Crypto Telegram Bot in Laravel",
"category" => "php"
]
];
複製程式碼
zip()
Zip 方法會將給定陣列的值與集合的值合併在一起。相同索引的值會新增在一起,這意味著,陣列的第一個值會與集合的第一個值合併。在這裡,我會使用我們在上面剛剛建立的集合。這對 Eloquent 集合同樣有效。
$zipped = $collection->zip([1, 2, 3]);
$zipped->all();
複製程式碼
JSON 響應會像這樣。
所以,基本上就是這樣。如果陣列的長度小於集合的長度,Laravel 會給剩下的 Collection
型別的元素末尾新增 null
。類似地,如果陣列的長度比集合的長度大,Laravel 會給 Collection
型別的元素新增 null
,然後再接著陣列的值。
whereNotIn()
您可以使用 whereNotIn
方法簡單地按照給定陣列中未包含的鍵值過濾集合。 它基本上與 whereIn
相反。 此外,此方法在匹配值時使用寬鬆比較 ==
。
讓我們過濾 $collection
,其中 user_id
既不是 1
也不是 2
的。
$collection->whereNotIn('user_id', [1, 2]);
複製程式碼
上面的語句將只返回 $collection
中的最後一項。 第一個引數是鍵,第二個引數是值陣列。 如果是 eloquent 的話,第一個引數將是列的名稱,第二個引數將是一個值陣列。
max()
max
方法返回給定鍵的最大值。 你可以通過呼叫max來找到最大的 user_id
。 它通常用於價格或任何其他數字之類的比較,但為了演示,我們使用 user_id
。 它也可以用於字串,在這種情況下,Z> a
。
$collection->max('user_id');
複製程式碼
上面的語句將返回最大的 user_id
,在我們的例子中是 3
。
pluck()
pluck
方法返回指定鍵的所有值。 它對於提取一列的值很有用。
$title = $collection->pluck('title');
$title->all();
複製程式碼
結果看起來像這樣。
[
"Helpers in Laravel",
"Testing in Laravel",
"Telegram Bot"
]
複製程式碼
使用 eloquent 時,可以將列名作為引數傳遞以提取值。 pluck
也接受第二個引數,對於 eloquent 的集合,它可以是另一個列名。 它將導致由第二個引數的值作為鍵的集合。
$title = $collection->pluck('user_id', 'title');
$title->all();
複製程式碼
結果如下:
[
"Helpers in Laravel" => 1,
"Testing in Laravel" => 2,
"Telegram Bot" => 3
]
複製程式碼
each()
each
是一種迭代整個集合的簡單方法。 它接受一個帶有兩個引數的回撥:它正在迭代的項和鍵。 Key 是基於 0 的索引。
$collection->each(function ($item, $key) {
info($item['user_id']);
});
複製程式碼
上面程式碼,只是記錄每個項的 user_id
。
在迭代 eloquent 集合時,您可以將所有列值作為項屬性進行訪問。 以下是我們如何迭代所有帖子。
$posts = App\Post::all();
$posts->each(function ($item, $key) {
// Do something
});
複製程式碼
如果回撥中返回 false,它將停止迭代專案。
$collection->each(function ($item, $key) {
// Tasks
if ($key == 1) {
return false;
}
});
複製程式碼
tap()
tap()
方法允許你隨時加入集合。 它接受回撥並傳遞並將集合傳遞給它。 您可以對專案執行任何操作,而無需更改集合本身。 因此,您可以在任何時候使用tap來加入集合,而不會改變集合。
$collection->whereNotIn('user_id', 3)
->tap(function ($collection) {
$collection = $collection->where('user_id', 1);
info($collection->values());
})
->all();
複製程式碼
在上面使用的 tap 方法中,我們修改了集合,然後記錄了值。 您可以對 tap 中的集合做任何您想做的事情。 上面命令的響應是:
[
[
"user_id" => "1",
"title" => "Helpers in Laravel",
"content" => "Create custom helpers in Laravel",
"category" => "php"
],
[
"user_id" => "2",
"title" => "Testing in Laravel",
"content" => "Testing File Uploads in Laravel",
"category" => "php"
]
]
複製程式碼
你可以看到 tap 不會修改集合例項。
pipe()
pipe
方法非常類似於 tap
方法,因為它們都在集合管道中使用。 pipe
方法將集合傳遞給回撥並返回結果。
$collection->pipe(function($collection) {
return $collection->min('user_id');
});
複製程式碼
上述命令的響應是 1
。 如果從 pipe
回撥中返回集合例項,也可以連結其他方法。
contains()
contains
方法只檢查集合是否包含給定值。 只傳遞一個引數時才會出現這種情況。
$contains = collect(['country' => 'USA', 'state' => 'NY']);
$contains->contains('USA');
// true
$contains->contains('UK');
// false
複製程式碼
如果將 鍵 / 值 對傳遞給 contains 方法,它將檢查給定的鍵值對是否存在。
$collection->contains('user_id', '1');
// true
$collection->contains('title', 'Not Found Title');
// false
複製程式碼
您還可以將回撥作為引數傳遞給回撥方法。 將對集合中的每個專案執行回撥,如果其中任何一個專案通過了真值測試,它將返回 true
否則返回 false
。
$collection->contains(function ($value, $key) {
return strlen($value['title']) < 13;
});
// true
複製程式碼
回撥函式接受當前迭代項和鍵的兩個引數值。 這裡我們只是檢查標題的長度是否小於13。在 Telegram Bot
中它是12,所以它返回 true
。
forget()
forget
只是從集合中刪除該項。 您只需傳遞一個鍵,它就會從集合中刪除該專案。
$forget = collect(['country' => 'usa', 'state' => 'ny']);
$forget->forget('country')->all();
複製程式碼
上面程式碼響應如下:
[
"state" => "ny"
]
複製程式碼
forget
不適用於多維陣列。
avg()
avg
方法返回平均值。 你只需傳遞一個鍵作為引數,avg
方法返回平均值。 你也可以使用 average
方法,它基本上是 avg
的別名。
$avg = collect([
['shoes' => 10],
['shoes' => 35],
['shoes' => 7],
['shoes' => 68],
])->avg('shoes');
複製程式碼
上面的程式碼返回 30
,這是所有四個數字的平均值。 如果你沒有將任何鍵傳遞給avg
方法並且所有項都是數字,它將返回所有數字的平均值。 如果鍵未作為引數傳遞且集合包含鍵/值對,則 avg
方法返回 0。
$avg = collect([12, 32, 54, 92, 37]);
$avg->avg();
複製程式碼
上面的程式碼返回 45.4
,這是所有五個數字的平均值。
您可以使用這些 laravel 集合方法在您自己的專案中處理集合。