الفرق بين المراجعتين لصفحة: «Laravel/collections»
رؤيا-بنعطية (نقاش | مساهمات) لا ملخص تعديل |
رؤيا-بنعطية (نقاش | مساهمات) لا ملخص تعديل |
||
(13 مراجعات متوسطة بواسطة نفس المستخدم غير معروضة) | |||
سطر 1: | سطر 1: | ||
== مقدمة== | |||
== | |||
يوفر الصنف <code>Illuminate\Support\Collection</code> غلافًا ملائمًا و مساعدًا على العمل مع مصفوفات البيانات. مثلًا، تفقد الشيفرة الموالية إذ سنستعمل المساعد <code>collect</code> لإنشاء نسخة <code>Collection</code> جديدة من المصفوفة، ننفذ الدالة <code>strtoupper</code> مع كل عنصر، ثم نحذف كل العناصر الفارغة:<syntaxhighlight lang="php"> | يوفر الصنف <code>Illuminate\Support\Collection</code> غلافًا ملائمًا و مساعدًا على العمل مع مصفوفات البيانات. مثلًا، تفقد الشيفرة الموالية إذ سنستعمل المساعد <code>collect</code> لإنشاء نسخة <code>Collection</code> جديدة من المصفوفة، ننفذ الدالة <code>strtoupper</code> مع كل عنصر، ثم نحذف كل العناصر الفارغة:<syntaxhighlight lang="php"> | ||
$collection = collect(['taylor', 'abigail', null])->map(function ($name) { | $collection = collect(['taylor', 'abigail', null])->map(function ($name) { | ||
سطر 9: | سطر 8: | ||
}); | }); | ||
</syntaxhighlight> | </syntaxhighlight>كما ترى، تسمح الدالة بسلسلة توابعها لتنفيذِ تخطيطِ دقيق و التحكم في حجم المصفوفة قيد العمل. بشكل عام، المجموعات غير قابلة للتغيير، أي أن كل تابع <code>collect</code> يعيد نسخة من كائن مجموعة جديد تمامًا. | ||
===إنشاء المجموعات=== | |||
كما ترى، تسمح الدالة بسلسلة توابعها لتنفيذِ تخطيطِ دقيق و التحكم في حجم المصفوفة قيد العمل. بشكل عام، المجموعات غير قابلة للتغيير، أي أن كل تابع <code>collect</code> يعيد نسخة من كائن مجموعة جديد تمامًا. | |||
=== إنشاء المجموعات === | |||
كما ذُكر سابقًا، يعيد التابع المساعد <code>collect</code> نسخة من كائن <code>Illuminate\Support\Collection</code> جديد لكل مصفوفة. لذا، يمكننا إنشاء مجموعة بسهولة<syntaxhighlight lang="php"> | كما ذُكر سابقًا، يعيد التابع المساعد <code>collect</code> نسخة من كائن <code>Illuminate\Support\Collection</code> جديد لكل مصفوفة. لذا، يمكننا إنشاء مجموعة بسهولة<syntaxhighlight lang="php"> | ||
$collection = collect([1, 2, 3]); | $collection = collect([1, 2, 3]); | ||
</syntaxhighlight> | </syntaxhighlight>'''ملاحظة''': نتائج طلبات [[Laravel/eloquent|Eloquent]] تكون دائمًا على شكل كائن <code>Collection</code>. | ||
===تمديد المجموعات=== | |||
=== تمديد المجموعات === | |||
المجموعات قابلة للتمديد، مما يسمح لك بإضافة توابع أخرى للصنف <code>Collection</code> في وقت التشغيل. مثلًا، الشيفرة التالية تضيف التابع <code>toUpper</code> إلى الصنف <code>Collection</code>:<syntaxhighlight lang="php"> | المجموعات قابلة للتمديد، مما يسمح لك بإضافة توابع أخرى للصنف <code>Collection</code> في وقت التشغيل. مثلًا، الشيفرة التالية تضيف التابع <code>toUpper</code> إلى الصنف <code>Collection</code>:<syntaxhighlight lang="php"> | ||
use Illuminate\Support\Str; | use Illuminate\Support\Str; | ||
سطر 35: | سطر 28: | ||
// ['FIRST', 'SECOND'] | // ['FIRST', 'SECOND'] | ||
</syntaxhighlight> | </syntaxhighlight>في العادة، عليك ذكر الإضافات للصنف <code>Collection</code> في مزود الخدمات. | ||
==التوابع المتاحة== | |||
في العادة، عليك ذكر الإضافات للصنف <code>Collection</code> في مزود الخدمات. | |||
في بقية هذا التوثيق، سنناقش كل تابع متوافر في الصنف <code>Collection</code>. تذكر أنّ كل التوابع يمكن سلسلتها معًا لمعالجة المصفوفة بيسر. بالإضافة ألى ذلك، تقريبًا كل التوابع تعيد نسخة جديدة من الكائن <code>Collection</code> مما يحافظ على المجموعة الأصلية عند الحاجة: | في بقية هذا التوثيق، سنناقش كل تابع متوافر في الصنف <code>Collection</code>. تذكر أنّ كل التوابع يمكن سلسلتها معًا لمعالجة المصفوفة بيسر. بالإضافة ألى ذلك، تقريبًا كل التوابع تعيد نسخة جديدة من الكائن <code>Collection</code> مما يحافظ على المجموعة الأصلية عند الحاجة: | ||
===<code>()all</code>=== | |||
يعيد التابع المصفوفة المقصودة على شكل مجموعة:<syntaxhighlight lang="php"> | |||
يعيد التابع | |||
collect([1, 2, 3])->all(); | collect([1, 2, 3])->all(); | ||
// [1, 2, 3] | // [1, 2, 3] | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()average</code>=== | |||
اسم بديل للتابع <code>avg</code>. | اسم بديل للتابع <code>avg</code>. | ||
===<code>()avg</code>=== | |||
يعيد التابع قيمة المتوسط الحسابي للمفتاح الممرّر:<syntaxhighlight lang="php"> | |||
يعيد التابع | |||
$average = collect([['foo' => 10], ['foo' => 10], ['foo' => 20], ['foo' => 40]])->avg('foo'); | $average = collect([['foo' => 10], ['foo' => 10], ['foo' => 20], ['foo' => 40]])->avg('foo'); | ||
// 20 | // 20 | ||
سطر 166: | سطر 49: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()chunk</code>=== | |||
يقسم التابع المجموعة لعدة مجموعات أصغر بحجم معين:<syntaxhighlight lang="php"> | |||
يقسم التابع | |||
$collection = collect([1, 2, 3, 4, 5, 6, 7]); | $collection = collect([1, 2, 3, 4, 5, 6, 7]); | ||
$chunks = $collection->chunk(4); | $chunks = $collection->chunk(4); | ||
سطر 176: | سطر 58: | ||
</syntaxhighlight> | </syntaxhighlight>هذا التابع مفيد خاصة في الواجهات عند العمل مع نظام شبكي "grid" مثل <code>Bootstrap</code>. تخيل أنك تريد عرض مجموعة من نماذج [[Laravel/eloquent|Eloquent]] في شبكة:<syntaxhighlight lang="php"> | ||
هذا التابع مفيد خاصة في الواجهات عند العمل مع نظام شبكي "grid" مثل <code>Bootstrap</code>. تخيل أنك تريد عرض مجموعة من نماذج [[Laravel/eloquent|Eloquent]] في شبكة:<syntaxhighlight lang="php"> | |||
@foreach ($products->chunk(3) as $chunk) | @foreach ($products->chunk(3) as $chunk) | ||
سطر 188: | سطر 68: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()collapse</code>=== | |||
يُسقط التابع مجموعة من المصفوفات في مجموعة واحدة ذات بعد واحد:<syntaxhighlight lang="php"> | |||
يُسقط التابع | |||
$collection = collect([[1, 2, 3], [4, 5, 6], [7, 8, 9]]); | $collection = collect([[1, 2, 3], [4, 5, 6], [7, 8, 9]]); | ||
$collapsed = $collection->collapse(); | $collapsed = $collection->collapse(); | ||
سطر 199: | سطر 78: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()combine</code>=== | |||
يدمج التابع مفاتيح المجموعة مع قيم من مجموعة أو مصفوفة أخرى:<syntaxhighlight lang="php"> | |||
يدمج التابع | |||
$collection = collect(['name', 'age']); | $collection = collect(['name', 'age']); | ||
$combined = $collection->combine(['George', 29]); | $combined = $collection->combine(['George', 29]); | ||
سطر 210: | سطر 88: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()concat</code>=== | |||
يضيف التابع المصفوفة الممررة أو قيم المجموعة المُمَرَّرة لآخر المجموعة:<syntaxhighlight lang="php"> | |||
يضيف التابع | |||
$collection = collect(['John Doe']); | $collection = collect(['John Doe']); | ||
$concatenated = $collection->concat(['Jane Doe'])->concat(['name' => 'Johnny Doe']); | $concatenated = $collection->concat(['Jane Doe'])->concat(['name' => 'Johnny Doe']); | ||
سطر 221: | سطر 98: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()contains</code>=== | |||
يحدد التابع إذا كانت المجموعة تحتوي على عنصرٍ محدِّد أم لا:<syntaxhighlight lang="php"> | |||
يحدد التابع | |||
$collection = collect(['name' => 'Desk', 'price' => 100]); | $collection = collect(['name' => 'Desk', 'price' => 100]); | ||
$collection->contains('Desk'); | $collection->contains('Desk'); | ||
سطر 234: | سطر 110: | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك أيضًا تمرير زوجٍ من المفتاح/القيمة إلى التابع الذي سيحدد إذا كان الثنائي موجودًا أم لا:<syntaxhighlight lang="php"> | ||
يمكنك أيضًا تمرير زوجٍ من المفتاح/القيمة إلى التابع الذي سيحدد إذا كان الثنائي موجودًا أم لا:<syntaxhighlight lang="php"> | |||
$collection = collect([ | $collection = collect([ | ||
سطر 248: | سطر 122: | ||
</syntaxhighlight> | </syntaxhighlight>أخيرًا، يمكنك تمرير دالة رد نداء إلى التابع <code>contains</code> لتقوم بعملية التحقق من وجود القيمة بنفسك:<syntaxhighlight lang="php"> | ||
أخيرًا، يمكنك تمرير دالة رد نداء إلى التابع <code>contains</code> لتقوم بعملية التحقق من وجود القيمة بنفسك:<syntaxhighlight lang="php"> | |||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
$collection->contains(function ($value, $key) { | $collection->contains(function ($value, $key) { | ||
سطر 260: | سطر 132: | ||
</syntaxhighlight> | </syntaxhighlight>يقوم التابع بمقارنة بسيطة، أي أن سلسلة المحارف التي تحتوي على رقم تُعدّ مساويةً لعدد صحيحٍ بنفس القيمة الرقمية. استعمل التابع <code>containsStrict</code> لمقارنة أكثر صرامةً. | ||
===<code>()containsStrict</code>=== | |||
يقوم التابع بمقارنة بسيطة، أي أن سلسلة المحارف التي تحتوي على رقم تُعدّ مساويةً لعدد صحيحٍ بنفس القيمة الرقمية. استعمل التابع <code>containsStrict</code> لمقارنة أكثر صرامةً. | نفس الوظيفة التابع لكنها تستعمل مقارنةً صارمةً (strict). | ||
===<code>()count</code>=== | |||
يعيد التابع عدد عناصر المجموعة:<syntaxhighlight lang="php"> | |||
نفس الوظيفة التابع | $collection = collect([1, 2, 3, 4]); | ||
يعيد التابع | |||
$collection = collect([1, 2, 3, 4]); | |||
$collection->count(); | $collection->count(); | ||
سطر 276: | سطر 144: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()crossJoin</code>=== | |||
يقوم التابع بوصل تقاطعي بين قيم المجموعة والمصفوفة الممرّرة، ويعيد جداءً ديكارتيًا بكل المبادلات الممكنة:<syntaxhighlight lang="php"> | يقوم التابع بوصل تقاطعي بين قيم المجموعة والمصفوفة الممرّرة، ويعيد جداءً ديكارتيًا بكل المبادلات الممكنة:<syntaxhighlight lang="php"> | ||
$collection = collect([1, 2]); | $collection = collect([1, 2]); | ||
سطر 309: | سطر 176: | ||
*/ | */ | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()dd</code>=== | |||
يطبع التابع عناصر المجموعة وينهي تنفيذ السكربت:<syntaxhighlight lang="php"> | |||
يطبع التابع | |||
$collection = collect(['John Doe', 'Jane Doe']); | $collection = collect(['John Doe', 'Jane Doe']); | ||
$collection->dd(); | $collection->dd(); | ||
سطر 325: | سطر 190: | ||
*/ | */ | ||
</syntaxhighlight>إذا لم ترد إنهاء السكربت، فاستعمل التابع <code>dump</code> بدلًا من <code>dd</code>. | </syntaxhighlight>إذا لم ترد إنهاء السكربت، فاستعمل التابع <code>dump</code> بدلًا من <code>dd</code>. | ||
===<code>()diff</code>=== | |||
يقارن التابع المجموعة بمجموعة أخرى أو بمصفوفة PHP عادية اعتمادًا على قيمها. يعيد هذا التابع قيم المجموعة الأصلية غير الموجودة في المجموعة الممرّرة:<syntaxhighlight lang="php"> | |||
يقارن التابع | |||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
$diff = $collection->diff([2, 4, 6, 8]); | $diff = $collection->diff([2, 4, 6, 8]); | ||
سطر 336: | سطر 200: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()diffAssoc</code>=== | |||
يقارن التابع المجموعة بمجموعة أخرى أو بمصفوفة [[PHP]] بالاعتماد على المفاتيح والقيم. يعيد هذا التابع أزواج المفتاح/القيمة من المجموعة الأصلية غير الموجودة في المجموعة الممررة:<syntaxhighlight lang="php"> | |||
يقارن التابع | |||
$collection = collect([ | $collection = collect([ | ||
سطر 360: | سطر 223: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()diffKeys</code>=== | |||
يقارن هذا التابع المجموعة بمجموعة أخرى أو بمصفوفة PHP بالإرتكاز على المفاتيح، يعيد هذا التابع أزواج المفتاح/القيمة من المجموعة الأصلية غير الموجودة في المجموعة الممرّرة:<syntaxhighlight lang="php"> | |||
يقارن هذا التابع المجموعة بمجموعة أخرى أو بمصفوفة PHP بالإرتكاز على المفاتيح، يعيد هذا التابع أزواج المفتاح/القيمة من المجموعة الأصلية غير الموجودة في المجموعة الممرّرة: | |||
<syntaxhighlight lang="php"> | |||
$collection = collect([ | $collection = collect([ | ||
سطر 387: | سطر 248: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()dump</code>=== | |||
يطبع التابع عناصر المجموعة:<syntaxhighlight lang="php"> | |||
يطبع التابع | |||
$collection = collect(['John Doe', 'Jane Doe']); | $collection = collect(['John Doe', 'Jane Doe']); | ||
سطر 404: | سطر 264: | ||
*/ | */ | ||
</syntaxhighlight> | </syntaxhighlight>إذا أردت إيقاف تنفيذ السكربت بعد تفريغ المجموعة فاستعمل التابع <code>dd</code>. | ||
===<code>()each</code>=== | |||
إذا أردت إيقاف تنفيذ السكربت بعد تفريغ المجموعة فاستعمل التابع <code>dd</code>. | يكرّر التابع عناصر المجموعة واحدًا بواحد ويمرّرها لدالة رد نداء:<syntaxhighlight lang="php"> | ||
يكرّر التابع | |||
$collection->each(function ($item, $key) { | $collection->each(function ($item, $key) { | ||
سطر 416: | سطر 273: | ||
</syntaxhighlight> | </syntaxhighlight>إذا أردت إيقاف التكرار، أعد القيمة <code>false</code> من دالة رد النداء:<syntaxhighlight lang="php"> | ||
إذا أردت إيقاف التكرار، أعد القيمة <code>false</code> من دالة رد النداء:<syntaxhighlight lang="php"> | |||
$collection->each(function ($item, $key) { | $collection->each(function ($item, $key) { | ||
سطر 427: | سطر 283: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()eachSpread</code>=== | |||
يكرّّر التابع عناصر المجموعة ويمرّر كل عنصر متداخل لدالة رد النداء:<syntaxhighlight lang="php"> | |||
يكرّّر التابع | |||
$collection = collect([['John Doe', 35], ['Jane Doe', 33]]); | $collection = collect([['John Doe', 35], ['Jane Doe', 33]]); | ||
$collection->eachSpread(function ($name, $age) { | $collection->eachSpread(function ($name, $age) { | ||
سطر 437: | سطر 291: | ||
}); | }); | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك إيقاف التكرار بإعادة القيمة <code>false</code> من دالة رد النداء.<syntaxhighlight lang="php"> | ||
يمكنك إيقاف التكرار بإعادة القيمة <code>false</code> من دالة رد النداء.<syntaxhighlight lang="php"> | |||
$collection->eachSpread(function ($name, $age) { | $collection->eachSpread(function ($name, $age) { | ||
سطر 447: | سطر 299: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()every</code>=== | |||
يمكن استعمال التابع للتأكد من أن كل عناصر المجموعة تحقق شرطًا معينًا:<syntaxhighlight lang="php"> | |||
يمكن استعمال التابع | |||
collect([1, 2, 3, 4])->every(function ($value, $key) { | collect([1, 2, 3, 4])->every(function ($value, $key) { | ||
سطر 459: | سطر 310: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
=== <code>()except</code> === | |||
يعيد التابع كل عناصر المجموعة باستثناء العناصر بالمفاتيح المحدَّدة:<syntaxhighlight lang="php"> | |||
$collection = collect(['product_id' => 1, 'price' => 100, 'discount' => false]); | $collection = collect(['product_id' => 1, 'price' => 100, 'discount' => false]); | ||
$filtered = $collection->except(['price', 'discount']); | $filtered = $collection->except(['price', 'discount']); | ||
سطر 469: | سطر 320: | ||
</syntaxhighlight> | </syntaxhighlight>لعكس وظيفة <code>except</code>، انظر التابع <code>only</code>. | ||
===<code>()filter</code>=== | |||
لعكس وظيفة <code>except</code>، انظر التابع <code>only</code>. | يرشِّح التابع عناصر المجموعة ويُبقي فقط العناصر التي تحقق شرطًا معينًا:<syntaxhighlight lang="php"> | ||
=== | |||
يرشِّح التابع | |||
$collection = collect([1, 2, 3, 4]); | $collection = collect([1, 2, 3, 4]); | ||
$filtered = $collection->filter(function ($value, $key) { | $filtered = $collection->filter(function ($value, $key) { | ||
سطر 487: | سطر 334: | ||
</syntaxhighlight> | </syntaxhighlight>إذا لم توفّر نداء للتابع، يحذف <code>filter</code> كل العناصر المساوية للقيمة <code>false</code>:<syntaxhighlight lang="php"> | ||
إذا لم توفّر نداء للتابع، يحذف <code>filter</code> كل العناصر المساوية للقيمة <code>false</code>: | |||
<syntaxhighlight lang="php"> | |||
$collection = collect([1, 2, 3, null, false, , 0, []]); | $collection = collect([1, 2, 3, null, false, , 0, []]); | ||
$collection->filter()->all(); | $collection->filter()->all(); | ||
سطر 498: | سطر 341: | ||
</syntaxhighlight> | </syntaxhighlight>لعكس وظيفة <code>filter</code> انظر التابع <code>reject</code>. | ||
===<code>()first</code>=== | |||
لعكس وظيفة <code>filter</code> انظر التابع <code>reject</code>. | يرجع التابع العنصر الأول من المجموعة الذي يحقق شرطًا معينًا:<syntaxhighlight lang="php"> | ||
collect([1, 2, 3, 4])->first(function ($value, $key) { | |||
=== | |||
يرجع التابع | |||
collect([1, 2, 3, 4])->first(function ($value, $key) { | |||
return $value > 2; | return $value > 2; | ||
سطر 510: | سطر 350: | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك أيضًا استدعاء التابع <code>first</code> دون معامل، وسيعيد العنصر الأول من المجموعة، وإذا كانت المجموعة فارغةً، فستعاد القيمة <code>null</code>:<syntaxhighlight lang="php"> | ||
يمكنك أيضًا استدعاء التابع <code>first</code> دون معامل، وسيعيد العنصر الأول من المجموعة، وإذا كانت المجموعة فارغةً، فستعاد القيمة <code>null</code>: | |||
<syntaxhighlight lang="php"> | |||
collect([1, 2, 3, 4])->first(); | collect([1, 2, 3, 4])->first(); | ||
سطر 520: | سطر 357: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()firstWhere</code>=== | |||
يعيد التابع العنصر الأول من المجموعة الموافق لزوج المفتاح/القيمة الممرّر:<syntaxhighlight lang="php"> | |||
يعيد التابع | |||
$collection = collect([ | $collection = collect([ | ||
سطر 536: | سطر 372: | ||
</syntaxhighlight> | </syntaxhighlight>يمكن أيضًا استعمال التابع مع عامل مقارنة:<syntaxhighlight lang="php"> | ||
يمكن أيضًا استعمال التابع مع عامل مقارنة:<syntaxhighlight lang="php"> | |||
$collection->firstWhere('age', '>=', 18); | $collection->firstWhere('age', '>=', 18); | ||
سطر 545: | سطر 379: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()flatMap</code>=== | |||
ينفذ التابع حلقة تكرار في المجموعة، فيمرر قيمة كل تكرار لنداء معين. يمكن للنداء تغيير العنصر وإرجاعه وبالتالي يكوّن مجموعةً جديدة من العناصر المغيَّرة. ثم تُسطَّح المجموعة حسب مستواها:<syntaxhighlight lang="php"> | |||
ينفذ التابع | |||
$collection = collect([ | $collection = collect([ | ||
سطر 566: | سطر 399: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()flatten</code>=== | |||
يُسطِّح التابع مجموعة متعددة الأبعاد لمجموعة ذات بعد واحد:<syntaxhighlight lang="php"> | |||
يُسطِّح التابع | |||
$collection = collect(['name' => 'taylor', 'languages' => ['php', 'javascript']]); | $collection = collect(['name' => 'taylor', 'languages' => ['php', 'javascript']]); | ||
$flattened = $collection->flatten(); | $flattened = $collection->flatten(); | ||
$flattened->all(); | $flattened->all(); | ||
سطر 588: | سطر 418: | ||
$products = $collection->flatten(1); | $products = $collection->flatten(1); | ||
$products->values()->all(); | $products->values()->all(); | ||
سطر 599: | سطر 428: | ||
</syntaxhighlight>في هذا المثال، سيتسبب عدم توفير عمق في تسطيح المصفوفات الداخلية لتصبح النتيجة <code>['iPhone 6S', 'Apple', 'Galaxy S7', 'Samsung']</code>. مما يوفّر مستوى عمق يسمح بتحديد مستوى التداخل الذي سيتم تسطيحه. | </syntaxhighlight>في هذا المثال، سيتسبب عدم توفير عمق في تسطيح المصفوفات الداخلية لتصبح النتيجة <code>['iPhone 6S', 'Apple', 'Galaxy S7', 'Samsung']</code>. مما يوفّر مستوى عمق يسمح بتحديد مستوى التداخل الذي سيتم تسطيحه. | ||
===<code>()flip</code>=== | |||
يُبدِّل التابع المفتاح بقيمته:<syntaxhighlight lang="php"> | |||
يُبدِّل التابع | |||
$collection = collect(['name' => 'taylor', 'framework' => 'laravel']); | $collection = collect(['name' => 'taylor', 'framework' => 'laravel']); | ||
$flipped = $collection->flip(); | $flipped = $collection->flip(); | ||
$flipped->all(); | $flipped->all(); | ||
// ['taylor' => 'name', 'laravel' => 'framework'] | // ['taylor' => 'name', 'laravel' => 'framework'] | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()forget</code>=== | |||
يحذف التابع عنصرًا من المجموعة باستخدام مفتاحه:<syntaxhighlight lang="php"> | |||
يحذف التابع | |||
$collection = collect(['name' => 'taylor', 'framework' => 'laravel']); | $collection = collect(['name' => 'taylor', 'framework' => 'laravel']); | ||
$collection->forget('name'); | $collection->forget('name'); | ||
$collection->all(); | $collection->all(); | ||
// ['framework' => 'laravel'] | // ['framework' => 'laravel'] | ||
</syntaxhighlight> | </syntaxhighlight>'''تنبيه:''' على عكس جل توابع المجموعات، لا يعيد <code>forget</code> مجموعةً جديدةً بل يغيّر في المجموعة التي استدعي هذا التابع عليها. | ||
===<code>()forPage</code>=== | |||
=== | يعيد التابع مجموعة تحتوي العناصر الموجودة في رقم الصفحة الممرّر. يقبل التابع رقم صفحة كمعامل أول وعدد العناصر التي يجب إظهارها في الصفحة كمعامل ثاني:<syntaxhighlight lang="php"> | ||
يعيد التابع | |||
$collection = collect([1, 2, 3, 4, 5, 6, 7, 8, 9]); | $collection = collect([1, 2, 3, 4, 5, 6, 7, 8, 9]); | ||
$chunk = $collection->forPage(2, 3); | $chunk = $collection->forPage(2, 3); | ||
$chunk->all(); | $chunk->all(); | ||
سطر 633: | سطر 453: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()get</code>=== | |||
يعيد التابع قيمة العنصر ذي المفتاح المُمرَّر إلى التابع. إذا كان المفتاح غير موجود فستعاد القيمة <code>null</code>:<syntaxhighlight lang="php"> | |||
يعيد التابع | |||
<syntaxhighlight lang="php"> | |||
$collection = collect(['name' => 'taylor', 'framework' => 'laravel']); | $collection = collect(['name' => 'taylor', 'framework' => 'laravel']); | ||
$value = $collection->get('name'); | $value = $collection->get('name'); | ||
سطر 646: | سطر 463: | ||
</syntaxhighlight>يمكنك تمرير قيمة أولية اختيارية كمعامل ثاني:<syntaxhighlight lang="php"> | </syntaxhighlight>يمكنك تمرير قيمة أولية اختيارية كمعامل ثاني:<syntaxhighlight lang="php"> | ||
$collection = collect(['name' => 'taylor', 'framework' => 'laravel']); | $collection = collect(['name' => 'taylor', 'framework' => 'laravel']); | ||
$value = $collection->get('foo', 'default-value'); | $value = $collection->get('foo', 'default-value'); | ||
// default-value | // default-value | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك حتى تمرير دالة رد نداء. تُعاد القيمة المُعادة من دالة رد النداء في حال عدم وجود المفتاح:<syntaxhighlight lang="php"> | ||
يمكنك حتى تمرير دالة رد نداء. تُعاد القيمة المُعادة من دالة رد النداء في حال عدم وجود المفتاح:<syntaxhighlight lang="php"> | |||
$collection->get('email', function () { | $collection->get('email', function () { | ||
سطر 662: | سطر 476: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()groupBy</code>=== | |||
يُجمِّع التابع العناصر حسب قيمة المفتاح الممرّر إلى التابع:<syntaxhighlight lang="php"> | |||
يُجمِّع التابع | |||
$collection = collect([ | $collection = collect([ | ||
سطر 673: | سطر 486: | ||
$grouped = $collection->groupBy('account_id'); | $grouped = $collection->groupBy('account_id'); | ||
$grouped->toArray(); | $grouped->toArray(); | ||
/* | /* | ||
[ | [ | ||
'account-x10' => [ | 'account-x10' => [ | ||
سطر 685: | سطر 496: | ||
'account-x11' => [ | 'account-x11' => [ | ||
['account_id' => 'account-x11', 'product' => 'Desk'], | ['account_id' => 'account-x11', 'product' => 'Desk'], | ||
], | |||
] | ] | ||
*/ | */ | ||
</syntaxhighlight> | </syntaxhighlight>بدل تمرير سلسلة محارف <code>key</code>، يمكنك تمرير دالة رد نداء التي يجب أن تعيد القيمة التي تريد أن تكون مفتاح التجميع:<syntaxhighlight lang="php"> | ||
بدل تمرير سلسلة محارف <code>key</code>، يمكنك تمرير دالة رد نداء التي يجب أن تعيد القيمة التي تريد أن تكون مفتاح التجميع:<syntaxhighlight lang="php"> | |||
$grouped = $collection->groupBy(function ($item, $key) { | $grouped = $collection->groupBy(function ($item, $key) { | ||
سطر 712: | سطر 522: | ||
</syntaxhighlight> | </syntaxhighlight>يمكن تمرير عدة معايير تجميع كمصفوفة، يُطبّق كل عنصر من المصفوفة على مستوى العمق الملائم في مصفوفة متعددة الأبعاد:<syntaxhighlight lang="php"> | ||
يمكن تمرير عدة معايير تجميع كمصفوفة، يُطبّق كل عنصر من المصفوفة على مستوى العمق الملائم في مصفوفة متعددة الأبعاد:<syntaxhighlight lang="php"> | |||
$data = new Collection([ | $data = new Collection([ | ||
سطر 758: | سطر 567: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()has</code>=== | |||
يحدد التابع إذا كان المفتاح موجودًا في المجموعة أم لا:<syntaxhighlight lang="php"> | |||
يحدد التابع | |||
$collection = collect(['account_id' => 1, 'product' => 'Desk']); | $collection = collect(['account_id' => 1, 'product' => 'Desk']); | ||
$collection->has('product'); | $collection->has('product'); | ||
سطر 769: | سطر 576: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()implode</code>=== | |||
يضم التابع عناصر المجموعة في سلسلة حرفية. تعتمد التوابع على نوع العناصر في المجموعة. إذا كانت المجموعة تحتوي مصفوفات أو كائنات، يجب تمرير مفتاح الخاصيات التي تريد ضمّها وعلامة الربط "glue" الذي تريد استعماله بين القيم:<syntaxhighlight lang="php"> | |||
يضم التابع | |||
$collection = collect([ | $collection = collect([ | ||
سطر 783: | سطر 589: | ||
</syntaxhighlight> | </syntaxhighlight>إذا كانت المجموعة تحتوي سلاسل نصية أو قيمًا رقميةً بسيطةً، فمرّر علامة الربط فقط كمعامل إلى التابع:<syntaxhighlight lang="php"> | ||
إذا كانت المجموعة تحتوي سلاسل نصية أو قيمًا رقميةً بسيطةً، فمرّر علامة الربط فقط كمعامل إلى التابع:<syntaxhighlight lang="php"> | |||
collect([1, 2, 3, 4, 5])->implode('-'); | collect([1, 2, 3, 4, 5])->implode('-'); | ||
سطر 792: | سطر 596: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()intersect</code>=== | |||
يحذف التابع أي قيمة في المجموعة الأصلية غير موجودة في المجموعة أو المصفوفة الممرّرة. تحافظ المجموعة النهائية على مفاتيح المجموعة الأصلية:<syntaxhighlight lang="php"> | |||
يحذف التابع | |||
$collection = collect(['Desk', 'Sofa', 'Chair']); | $collection = collect(['Desk', 'Sofa', 'Chair']); | ||
$intersect = $collection->intersect(['Desk', 'Chair', 'Bookcase']); | $intersect = $collection->intersect(['Desk', 'Chair', 'Bookcase']); | ||
$intersect->all(); | $intersect->all(); | ||
سطر 805: | سطر 606: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()intersectByKeys</code>=== | |||
يحذف التابع أي مفتاح من المجموعة الأصلية غير موجود في المجموعة أو المصفوفة الممرّرة:<syntaxhighlight lang="php"> | يحذف التابع أي مفتاح من المجموعة الأصلية غير موجود في المجموعة أو المصفوفة الممرّرة:<syntaxhighlight lang="php"> | ||
$collection = collect([ | $collection = collect([ | ||
سطر 824: | سطر 624: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()isEmpty</code>=== | |||
يعيد التابع القيمة <code>true</code> إذا كانت المجموعة فارغة وإلا فسيعيد <code>false</code>:<syntaxhighlight lang="php"> | |||
يعيد التابع | |||
collect([])->isEmpty(); | collect([])->isEmpty(); | ||
سطر 833: | سطر 632: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()isNotEmpty</code>=== | |||
يعيد التابع القيمة <code>true</code> إذا لم تكن المجموعة فارغة، وإلا فسيعيد <code>false</code>:<syntaxhighlight lang="php"> | |||
يعيد التابع | |||
collect([])->isNotEmpty(); | collect([])->isNotEmpty(); | ||
سطر 842: | سطر 640: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()keyBy</code>=== | |||
يضيف التابع مفاتيح للمجموعة، إذا وُجد أكثر من عنصر بنفس المفتاح، فسيضاف الأخير فقط إلى المجموعة الجديدة:<syntaxhighlight lang="php"> | |||
يضيف التابع | |||
$collection = collect([ | $collection = collect([ | ||
سطر 863: | سطر 660: | ||
*/ | */ | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك تمرير نداء للتابع. يجب أن يعيد النداء القيمة التي ستستعمل كمفتاح للمجموعة:<syntaxhighlight lang="php"> | ||
يمكنك تمرير نداء للتابع. يجب أن يعيد النداء القيمة التي ستستعمل كمفتاح للمجموعة:<syntaxhighlight lang="php"> | |||
$keyed = $collection->keyBy(function ($item) { | $keyed = $collection->keyBy(function ($item) { | ||
سطر 881: | سطر 677: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()keys</code>=== | |||
يعيد التابع مجموعة متكونة من كل المفاتيح:<syntaxhighlight lang="php"> | يعيد التابع مجموعة متكونة من كل المفاتيح:<syntaxhighlight lang="php"> | ||
$collection = collect([ | $collection = collect([ | ||
سطر 898: | سطر 693: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()last</code>=== | |||
يعيد التابع العنصر الأخير الذي يحقق شرطًا معينًا. إذا كانت المجموعة فارغةً، فسيعيد التابع القيمة <code>null</code><syntaxhighlight lang="php"> | |||
يعيد التابع | |||
: collect([1, 2, 3, 4])->last(); | : collect([1, 2, 3, 4])->last(); | ||
سطر 907: | سطر 701: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()macro</code>=== | |||
يسمح التابع بإضافة توابع للصنف <code>Collection</code> في وقت التشغيل. راجع التوثيق حول تمديد المجموعات لمزيد من المعلومات. | |||
يسمح التابع | ===<code>()make</code>=== | ||
يُنشِئ التابع نسخة مجموعة جديدة. راجع قسم إنشاء المجموعات. | |||
=== | ===<code>()map</code>=== | ||
يُنشِئ التابع | |||
=== | |||
يكرّر التابع عناصر المجموعة و يمرّر كل قيمة لدالة رد نداء معيّنة. يمكن لدالة رد اللنداء تغيير العنصر وإعادته، وبالتالي تكوين مجموعة جديدة من العناصر المغيّرة:<syntaxhighlight lang="php"> | يكرّر التابع عناصر المجموعة و يمرّر كل قيمة لدالة رد نداء معيّنة. يمكن لدالة رد اللنداء تغيير العنصر وإعادته، وبالتالي تكوين مجموعة جديدة من العناصر المغيّرة:<syntaxhighlight lang="php"> | ||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
سطر 928: | سطر 719: | ||
</syntaxhighlight> | </syntaxhighlight><u>تنبيه</u>: كأغلب توابع المجموعات، يعيد <code>map</code> مجموعة جديدة ولا يغير المجموعة الأصلية. إذا أردت تغيير المجموعة الأصلية فاستعمل التابع <code>transform</code>. | ||
===<code>()mapInfo</code>=== | |||
<u>تنبيه</u>: كأغلب توابع المجموعات، يعيد <code>map</code> مجموعة جديدة ولا يغير المجموعة الأصلية. إذا أردت تغيير المجموعة الأصلية فاستعمل التابع <code>transform</code>. | يكرّر التابع المجموعة وينشِئ نسخةً جديدةً من صنف معين عبر تمرير القيمة للتابع الباني للصنف:<syntaxhighlight lang="php"> | ||
=== | |||
يكرّر التابع | |||
class Currency { | class Currency { | ||
سطر 958: | سطر 746: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()mapSpread</code>=== | |||
يكرّر التابع عناصر المجموعة ويمرّر كل عنصر متداخل لدالة رد نداء. يمكن لدالة رد النداء تغيير العنصر وإعادته، وبالتالي تكوين مجموعة جديدة من العناصر المغيرة:<syntaxhighlight lang="php"> | يكرّر التابع عناصر المجموعة ويمرّر كل عنصر متداخل لدالة رد نداء. يمكن لدالة رد النداء تغيير العنصر وإعادته، وبالتالي تكوين مجموعة جديدة من العناصر المغيرة:<syntaxhighlight lang="php"> | ||
$collection = collect([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]); | $collection = collect([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]); | ||
سطر 976: | سطر 763: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()mapToGroups</code>=== | |||
يُجمّع التابع عناصر المجموعة باستخدام دالة رد النداء المعيّنة. تعيد دالة رد النداء مصفوفة تجميعية تحتوي زوج المفتاح/القيمة واحد، وبالتالي تكوين مجموعة من القيم المجمَّعة:<syntaxhighlight lang="php"> | |||
يُجمّع التابع | |||
$collection = collect([ | $collection = collect([ | ||
سطر 1٬015: | سطر 801: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()mapWithKeys</code>=== | |||
يكرّر التابع المجموعة ويمرّر القيم لدالة رد نداء معيّنة. يعيد التابع مصفوفة تجميعية تحتوي زوج المفتاح/القيمة واحد:<syntaxhighlight lang="php"> | |||
يكرّر التابع | |||
$collection = collect([ | $collection = collect([ | ||
سطر 1٬048: | سطر 833: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()max</code>=== | |||
يعيد التابع القيمة القصوى في لمفتاح معين:<syntaxhighlight lang="php"> | يعيد التابع القيمة القصوى في لمفتاح معين:<syntaxhighlight lang="php"> | ||
$max = collect([['foo' => 10], ['foo' => 20]])->max('foo'); | $max = collect([['foo' => 10], ['foo' => 20]])->max('foo'); | ||
سطر 1٬058: | سطر 842: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()median</code>=== | |||
يعيد التابع القيمة الوسطية للمفتاح المعين:<syntaxhighlight lang="php"> | |||
يعيد التابع | |||
$median = collect([['foo' => 10], ['foo' => 10], ['foo' => 20], ['foo' => 40]])->median('foo'); | $median = collect([['foo' => 10], ['foo' => 10], ['foo' => 20], ['foo' => 40]])->median('foo'); | ||
سطر 1٬071: | سطر 854: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()merge</code>=== | |||
يدمج التابع المصفوفة أو المجموعة الممرّرة مع المجموعة الأصلية، تلغي القيم الممرّرة القيم الأصلية:<syntaxhighlight lang="php"> | |||
يدمج التابع | |||
$collection = collect(['product_id' => 1, 'price' => 100]); | $collection = collect(['product_id' => 1, 'price' => 100]); | ||
$merged = $collection->merge(['price' => 200, 'discount' => false]); | $merged = $collection->merge(['price' => 200, 'discount' => false]); | ||
$merged->all(); | $merged->all(); | ||
سطر 1٬083: | سطر 863: | ||
</syntaxhighlight> | </syntaxhighlight>إذا كانت المفاتيح الممرّرة رقمية، تضاف القيم في آخر المجموعة:<syntaxhighlight lang="php"> | ||
إذا كانت المفاتيح الممرّرة رقمية، تضاف القيم في آخر المجموعة:<syntaxhighlight lang="php"> | |||
$collection = collect(['Desk', 'Chair']); | $collection = collect(['Desk', 'Chair']); | ||
$merged = $collection->merge(['Bookcase', 'Door']); | $merged = $collection->merge(['Bookcase', 'Door']); | ||
$merged->all(); | $merged->all(); | ||
سطر 1٬096: | سطر 872: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()min</code>=== | |||
يعيد التابع القيمة الأصغر لمفتاح معين:<syntaxhighlight lang="php"> | |||
يعيد التابع | |||
$min = collect([['foo' => 10], ['foo' => 20]])->min('foo'); | $min = collect([['foo' => 10], ['foo' => 20]])->min('foo'); | ||
سطر 1٬109: | سطر 884: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()mode</code>=== | |||
يعيد التابع قيمة المنوال لمفتاح معين:<syntaxhighlight lang="php"> | |||
يعيد التابع قيمة المنوال لمفتاح معين: | |||
<syntaxhighlight lang="php"> | |||
$mode = collect([['foo' => 10], ['foo' => 10], ['foo' => 20], ['foo' => 40]])->mode('foo'); | $mode = collect([['foo' => 10], ['foo' => 10], ['foo' => 20], ['foo' => 40]])->mode('foo'); | ||
سطر 1٬123: | سطر 896: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()nth</code>=== | |||
ينشِئ التابع مجموعةً جديدةً متكونةً من كل عنصر بعد n عناصر<syntaxhighlight lang="php"> | |||
ينشِئ التابع | |||
$collection = collect(['a', 'b', 'c', 'd', 'e', 'f']); | $collection = collect(['a', 'b', 'c', 'd', 'e', 'f']); | ||
سطر 1٬133: | سطر 905: | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك تمرير موضع البداية كمعامل ثاني:<syntaxhighlight lang="php"> | ||
يمكنك تمرير موضع البداية كمعامل ثاني:<syntaxhighlight lang="php"> | |||
$collection->nth(4, 1); | $collection->nth(4, 1); | ||
سطر 1٬142: | سطر 912: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()only</code>=== | |||
يعيد التابع العناصر في المجموعة ذات المفاتيح الممرّرة:<syntaxhighlight lang="php"> | |||
يعيد التابع | |||
$collection->nth(4, 1); | $collection->nth(4, 1); | ||
سطر 1٬150: | سطر 919: | ||
</syntaxhighlight> | </syntaxhighlight>لعكس وظيفة <code>only</code>، استعمل التابع <code>expect</code>. | ||
===<code>()pad</code>=== | |||
لعكس وظيفة <code>only</code>، استعمل التابع <code>expect</code>. | يملأ التابع المصفوفة بالقيمة الممرّرة حتى تصل للحجم المحدد. يشبه هذا التابع دالة <code>array_pad</code> في PHP.<syntaxhighlight lang="php"> | ||
=== | |||
يملأ التابع | |||
$collection = collect(['A', 'B', 'C']); | $collection = collect(['A', 'B', 'C']); | ||
$filtered = $collection->pad(5, 0); | $filtered = $collection->pad(5, 0); | ||
$filtered->all(); | $filtered->all(); | ||
سطر 1٬165: | سطر 929: | ||
$filtered = $collection->pad(-5, 0); | $filtered = $collection->pad(-5, 0); | ||
$filtered->all(); | $filtered->all(); | ||
سطر 1٬172: | سطر 935: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()partition</code>=== | |||
يمكن استعمال التابع مع الدالة <code>list</code> في PHP لتفريق العناصر التي تجتاز شرط صحة عن البقية:<syntaxhighlight lang="php"> | |||
يمكن استعمال التابع | |||
$collection = collect([1, 2, 3, 4, 5, 6]); | $collection = collect([1, 2, 3, 4, 5, 6]); | ||
سطر 1٬192: | سطر 954: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>pipe()</code>=== | |||
يمرّر التابع المجموعة لنداء معين ويعيد نتيجة دالة رد النداء:<syntaxhighlight lang="php"> | |||
يمرّر التابع | |||
$collection = collect([1, 2, 3]); | $collection = collect([1, 2, 3]); | ||
سطر 1٬206: | سطر 967: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()pluck</code>=== | |||
يسترجع التابع كل القيم من مفتاح ممرّر:<syntaxhighlight lang="php"> | يسترجع التابع كل القيم من مفتاح ممرّر:<syntaxhighlight lang="php"> | ||
$collection = collect([ | $collection = collect([ | ||
سطر 1٬222: | سطر 982: | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك أيضا تحديد مفاتيح المجموعة الناتجة:<syntaxhighlight lang="php"> | ||
يمكنك أيضا تحديد مفاتيح المجموعة الناتجة:<syntaxhighlight lang="php"> | |||
$plucked = $collection->pluck('name', 'product_id'); | $plucked = $collection->pluck('name', 'product_id'); | ||
سطر 1٬231: | سطر 990: | ||
</syntaxhighlight> | </syntaxhighlight>إذا وُجدت مفاتيح متشابهة، فسيضاف العنصر الأخير الموافق للمفتاح:<syntaxhighlight lang="php"> | ||
إذا وُجدت مفاتيح متشابهة، فسيضاف العنصر الأخير الموافق للمفتاح: | |||
<syntaxhighlight lang="php"> | |||
$collection = collect([ | $collection = collect([ | ||
سطر 1٬250: | سطر 1٬007: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()pop</code>=== | |||
يحذف التابع العنصر الأخير من المجموعة ويعيده:<syntaxhighlight lang="php"> | |||
يحذف التابع | |||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
سطر 1٬265: | سطر 1٬021: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()prepend</code>=== | |||
يضيف التابع عناصر في أول المجموعة:<syntaxhighlight lang="php"> | يضيف التابع عناصر في أول المجموعة:<syntaxhighlight lang="php"> | ||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
$collection->prepend(0); | $collection->prepend(0); | ||
$collection->all(); | $collection->all(); | ||
سطر 1٬277: | سطر 1٬030: | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك تمرير معامل ثاني لتحديد مفتاح العناصر المضافة:<syntaxhighlight lang="php"> | ||
يمكنك تمرير معامل ثاني لتحديد مفتاح العناصر المضافة:<syntaxhighlight lang="php"> | |||
$collection = collect(['one' => 1, 'two' => 2]); | $collection = collect(['one' => 1, 'two' => 2]); | ||
سطر 1٬290: | سطر 1٬041: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()pull</code>=== | |||
يحذف التابع عنصرًا من المجموعة ويعيده وذلك باستعمال مفتاحه:<syntaxhighlight lang="php"> | |||
يحذف التابع | |||
$collection = collect(['product_id' => 'prod-100', 'name' => 'Desk']); | $collection = collect(['product_id' => 'prod-100', 'name' => 'Desk']); | ||
سطر 1٬305: | سطر 1٬055: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()push</code>=== | |||
يضيف التابع عنصرًا في آخر المجموعة:<syntaxhighlight lang="php"> | يضيف التابع عنصرًا في آخر المجموعة:<syntaxhighlight lang="php"> | ||
$collection = collect([1, 2, 3, 4]); | $collection = collect([1, 2, 3, 4]); | ||
سطر 1٬318: | سطر 1٬067: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()put</code>=== | |||
يضع التابع المفتاح والقيمة في المجموعة:<syntaxhighlight lang="php"> | |||
يضع التابع | |||
$collection = collect(['product_id' => 1, 'name' => 'Desk']); | $collection = collect(['product_id' => 1, 'name' => 'Desk']); | ||
$collection->put('price', 100); | $collection->put('price', 100); | ||
$collection->all(); | $collection->all(); | ||
سطر 1٬331: | سطر 1٬077: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()random</code>=== | |||
يعيد التابع عنصرًا عشوائيًا من المجموعة:<syntaxhighlight lang="php"> | يعيد التابع عنصرًا عشوائيًا من المجموعة:<syntaxhighlight lang="php"> | ||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
$collection->random(); | $collection->random(); | ||
سطر 1٬341: | سطر 1٬085: | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك اختيار تمرير عدد للتابع لتحديد عدد العناصر التي تريد إعادتها عشوائيًا. يعيد التابع مجموعة في حال تمرير عدد العناصر المطلوبة:<syntaxhighlight lang="php"> | ||
يمكنك اختيار تمرير عدد للتابع لتحديد عدد العناصر التي تريد إعادتها عشوائيًا. يعيد التابع مجموعة في حال تمرير عدد العناصر المطلوبة:<syntaxhighlight lang="php"> | |||
$random = $collection->random(3); | $random = $collection->random(3); | ||
سطر 1٬351: | سطر 1٬093: | ||
</syntaxhighlight> | </syntaxhighlight>إذا كان عدد العناصر في المجموعة أقل من المطلوب فسيُطلق التابع الاستثناء <code>InvalidArgumentException</code>. | ||
===<code>()reduce</code>=== | |||
إذا كان عدد العناصر في المجموعة أقل من المطلوب فسيُطلق التابع الاستثناء <code>InvalidArgumentException</code>. | |||
=== | |||
يقلص التابع المجموعة لعنصر واحد بتمرير نتيجة كل تكرار نداء للتكرار الموالي:<syntaxhighlight lang="php"> | يقلص التابع المجموعة لعنصر واحد بتمرير نتيجة كل تكرار نداء للتكرار الموالي:<syntaxhighlight lang="php"> | ||
$collection = collect([1, 2, 3]); | $collection = collect([1, 2, 3]); | ||
$total = $collection->reduce(function ($carry, $item) { | $total = $collection->reduce(function ($carry, $item) { | ||
return $carry + $item; | return $carry + $item; | ||
}); | }); | ||
سطر 1٬367: | سطر 1٬105: | ||
</syntaxhighlight> | </syntaxhighlight>قيمة <code>carry$</code> في التكرار الأول <code>null</code>، لكن بإمكانك تمرير قيمة الأولية يرجعها التابع بدل <code>null</code> كمعامل ثاني للتابع:<syntaxhighlight lang="php"> | ||
قيمة <code>carry$</code> في التكرار الأول <code>null</code>، لكن بإمكانك تمرير قيمة الأولية يرجعها التابع بدل <code>null</code> كمعامل ثاني للتابع:<syntaxhighlight lang="php"> | |||
$collection->reduce(function ($carry, $item) { | $collection->reduce(function ($carry, $item) { | ||
سطر 1٬379: | سطر 1٬115: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()reject</code>=== | |||
يُستعمل التابع لترشيح المجموعة باستعمال دالة رد نداء معينة. يجب أن تعيد دالة رد النداء القيمة <code>true</code> ليُحذف العنصر من المجموعة الناتجة:<syntaxhighlight lang="php"> | |||
يُستعمل التابع | |||
$collection = collect([1, 2, 3, 4]); | $collection = collect([1, 2, 3, 4]); | ||
سطر 1٬394: | سطر 1٬129: | ||
</syntaxhighlight> | </syntaxhighlight>لعكس وظيفة <code>reject</code>، انظر التابع <code>filter</code>. | ||
===<code>()reverse</code>=== | |||
لعكس وظيفة <code>reject</code>، انظر التابع <code>filter</code>. | |||
=== | |||
يعكس التابع ترتيب عناصر المجموعة محافظًا على المفاتيح الأصلية:<syntaxhighlight lang="php"> | يعكس التابع ترتيب عناصر المجموعة محافظًا على المفاتيح الأصلية:<syntaxhighlight lang="php"> | ||
$collection = collect(['a', 'b', 'c', 'd', 'e']); | $collection = collect(['a', 'b', 'c', 'd', 'e']); | ||
سطر 1٬418: | سطر 1٬150: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()search</code>=== | |||
يبحث التابع عن قيمة معينة ويعيد مفتاحها. إذا لم توجد القيمة المطلوبة فسيعيد التابع القيمة <code>false</code>:<syntaxhighlight lang="php"> | |||
يبحث التابع عن قيمة معينة ويعيد مفتاحها. إذا لم توجد القيمة المطلوبة فسيعيد التابع القيمة <code>false</code>: | |||
<syntaxhighlight lang="php"> | |||
$collection = collect([2, 4, 6, 8]); | $collection = collect([2, 4, 6, 8]); | ||
$collection->search(4); | $collection->search(4); | ||
سطر 1٬429: | سطر 1٬158: | ||
</syntaxhighlight> | </syntaxhighlight>يقارن هذا التابع مقارنة غير صارمة أي أن سلسلةً نصيةً تحتوي على رقمٍ تعدّ مساويةً للقيمة الرقمية. لاستعمال مقارنة صارمة، مرّر <code>true</code> كمعامل ثاني إلى التابع:<syntaxhighlight lang="php"> | ||
$collection->search('4', true); | |||
يقارن هذا التابع مقارنة غير صارمة أي أن سلسلةً نصيةً تحتوي على رقمٍ تعدّ مساويةً للقيمة الرقمية. لاستعمال مقارنة صارمة، مرّر <code>true</code> كمعامل ثاني إلى التابع:<syntaxhighlight lang="php"> | |||
$collection->search('4', true); | |||
// false | // false | ||
</syntaxhighlight> | </syntaxhighlight>بشكلٍ بديل، يمكنك تمرير دالة رد النداء الخاصة بك للبحث عن العنصر الأول الذي يحقق شرط الصحة الذي تحدّده:<syntaxhighlight lang="php"> | ||
بشكلٍ بديل، يمكنك تمرير دالة رد النداء الخاصة بك للبحث عن العنصر الأول الذي يحقق شرط الصحة الذي تحدّده:<syntaxhighlight lang="php"> | |||
$collection->search(function ($item, $key) { | $collection->search(function ($item, $key) { | ||
سطر 1٬449: | سطر 1٬174: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()shift</code>=== | |||
يحذف التابع ويعيد العنصر الأول من المجموعة<syntaxhighlight lang="php"> | يحذف التابع ويعيد العنصر الأول من المجموعة<syntaxhighlight lang="php"> | ||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
سطر 1٬464: | سطر 1٬188: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()shuffle</code>=== | |||
يخلط التابع العناصر عشوائيًا:<syntaxhighlight lang="php"> | يخلط التابع العناصر عشوائيًا:<syntaxhighlight lang="php"> | ||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
سطر 1٬477: | سطر 1٬200: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()slice</code>=== | |||
يعيد التابع قطعة من المجموعة بدءًا من مكان محدّد:<syntaxhighlight lang="php"> | |||
يعيد التابع قطعة من المجموعة بدءًا من مكان محدّد: | |||
<syntaxhighlight lang="php"> | |||
$collection = collect([1, 2, 3, 4, 5, 6, 7, 8, 9, 10]); | $collection = collect([1, 2, 3, 4, 5, 6, 7, 8, 9, 10]); | ||
$slice = $collection->slice(4); | $slice = $collection->slice(4); | ||
$slice->all(); | $slice->all(); | ||
سطر 1٬490: | سطر 1٬209: | ||
</syntaxhighlight> | </syntaxhighlight>إذا أردت تحديد حجم القطعة مرّر الحجم كمعامل ثاني للتابع:<syntaxhighlight lang="php"> | ||
إذا أردت تحديد حجم القطعة مرّر الحجم كمعامل ثاني للتابع: | |||
<syntaxhighlight lang="php"> | |||
$slice = $collection->slice(4, 2); | $slice = $collection->slice(4, 2); | ||
سطر 1٬501: | سطر 1٬217: | ||
</syntaxhighlight> | </syntaxhighlight>تحافظ القطعة على المفاتيح الأصلية، إذا لم ترد الحفاظ عليها فاستخدم التابع <code>values</code> لإعادة تسميتها. | ||
===<code>()sort</code>=== | |||
تحافظ القطعة على المفاتيح الأصلية، إذا لم ترد الحفاظ عليها فاستخدم التابع <code>values</code> لإعادة تسميتها. | يُرتِّب التابع المجموعة. تحافظ المجموعة الناتجة على المفاتيح الأصلية لذا سنستعمل في المثال التابع <code>values</code> لإعادة تعيين المفاتيح لأعداد متتالية:<syntaxhighlight lang="php"> | ||
=== | |||
يُرتِّب التابع | |||
$collection = collect([5, 3, 1, 2, 4]); | $collection = collect([5, 3, 1, 2, 4]); | ||
سطر 1٬516: | سطر 1٬229: | ||
</syntaxhighlight> | </syntaxhighlight>إذا احتجت ترتيبًا أكثر تعقيدًا، يمكنك تمرير دالة رد نداء للمنطق المتبع في طريقة الترتيب الخاصة بك. راجع توثيق الدالة <code>uasort</code> في PHP وهي طريقة الترتيب الذي يعتمدها التابع <code>sort</code> وراء الكواليس. | ||
إذا احتجت ترتيبًا أكثر تعقيدًا، يمكنك تمرير دالة رد نداء للمنطق المتبع في طريقة الترتيب الخاصة بك. راجع توثيق الدالة <code>uasort</code> في PHP وهي طريقة الترتيب الذي يعتمدها التابع <code>sort</code> وراء الكواليس | |||
=== | '''ملاحظة:''' إذا احتجت إلى ترتيب مجموعة مصفوفات متداخلة أو كائنات فراجع التابعين <code>sortBy</code> و <code>sortByDesc</code>. | ||
===<code>()sortBy</code>=== | |||
يرتب التابع المجموعة حسب مفتاح ممرّر. تحافظ المجموعة المرتَّبة على المفاتيح الأصلية لذا في هذا المثال سنستعمل التابع values لإعادة تعيين المفاتيح لأعداد متتالية:<syntaxhighlight lang="php"> | يرتب التابع المجموعة حسب مفتاح ممرّر. تحافظ المجموعة المرتَّبة على المفاتيح الأصلية لذا في هذا المثال سنستعمل التابع values لإعادة تعيين المفاتيح لأعداد متتالية:<syntaxhighlight lang="php"> | ||
$collection = collect([ | $collection = collect([ | ||
سطر 1٬544: | سطر 1٬254: | ||
*/ | */ | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك تمرير دالة رد النداء الخاصة بك لتحديد طريقة الترتيب:<syntaxhighlight lang="php"> | ||
يمكنك تمرير دالة رد النداء الخاصة بك لتحديد طريقة الترتيب:<syntaxhighlight lang="php"> | |||
$collection = collect([ | $collection = collect([ | ||
سطر 1٬571: | سطر 1٬279: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()sortByDesc</code>=== | |||
هذا التابع شبيه بالتابع <code>sortBy</code> لكنه يرتب العناصر ترتيبًا معاكسًا. | هذا التابع شبيه بالتابع <code>sortBy</code> لكنه يرتب العناصر ترتيبًا معاكسًا. | ||
===<code>()sortKeys</code>=== | |||
يرتب التابع المجموعة حسب مفاتيح المصفوفة المعالجة:<syntaxhighlight lang="php"> | يرتب التابع المجموعة حسب مفاتيح المصفوفة المعالجة:<syntaxhighlight lang="php"> | ||
$collection = collect([ | $collection = collect([ | ||
سطر 1٬598: | سطر 1٬304: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()sortKeysDesc</code>=== | |||
هذا التابع شبيه بالتابع <code>sortKeys</code> لكنه يرتّب المجموعة ترتيبًا معاكسًا. | هذا التابع شبيه بالتابع <code>sortKeys</code> لكنه يرتّب المجموعة ترتيبًا معاكسًا. | ||
===<code>()splice</code>=== | |||
يحذف التابع ويعيد قطعةً من المجموعة بدءًا من موضع محدّد:<syntaxhighlight lang="php"> | |||
يحذف التابع | |||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
$chunk = $collection->splice(2); | $chunk = $collection->splice(2); | ||
$chunk->all(); | $chunk->all(); | ||
سطر 1٬617: | سطر 1٬319: | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك تمرير معامل ثاني لتحديد حجم القطعة:<syntaxhighlight lang="php"> | ||
يمكنك تمرير معامل ثاني لتحديد حجم القطعة:<syntaxhighlight lang="php"> | |||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
سطر 1٬633: | سطر 1٬333: | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك أيضًا تمرير معامل ثالث يحتوي عناصر جديدة لتعويض العناصر المحذوفة من المجموعة الأصلية:<syntaxhighlight lang="php"> | ||
يمكنك أيضًا تمرير معامل ثالث يحتوي عناصر جديدة لتعويض العناصر المحذوفة من المجموعة الأصلية: | |||
<syntaxhighlight lang="php"> | |||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
$chunk = $collection->splice(2, 1, [10, 11]); | $chunk = $collection->splice(2, 1, [10, 11]); | ||
$chunk->all(); | $chunk->all(); | ||
سطر 1٬651: | سطر 1٬346: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()split</code>=== | |||
يقسم التابع المجموعة لعدد ممرّر من المجموعات:<syntaxhighlight lang="php"> | يقسم التابع المجموعة لعدد ممرّر من المجموعات:<syntaxhighlight lang="php"> | ||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
سطر 1٬664: | سطر 1٬358: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()sum</code>=== | |||
يعيد التابع مجموع عناصر المجموعة:<syntaxhighlight lang="php"> | يعيد التابع مجموع عناصر المجموعة:<syntaxhighlight lang="php"> | ||
collect([1, 2, 3, 4, 5])->sum(); | collect([1, 2, 3, 4, 5])->sum(); | ||
سطر 1٬672: | سطر 1٬365: | ||
</syntaxhighlight> | </syntaxhighlight>إذا كانت المجموعة تحتوي مصفوفات متداخلة، يجب تمرير مفتاح لتحديد العناصر التي يجب جمعها:<syntaxhighlight lang="php"> | ||
إذا كانت المجموعة تحتوي مصفوفات متداخلة، يجب تمرير مفتاح لتحديد العناصر التي يجب جمعها:<syntaxhighlight lang="php"> | |||
$collection = collect([ | $collection = collect([ | ||
سطر 1٬686: | سطر 1٬377: | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك أيضًا تمرير دالة رد نداء خاصة بك لتحديد أي القيم ستُجمَع:<syntaxhighlight lang="php"> | ||
يمكنك أيضًا تمرير دالة رد نداء خاصة بك لتحديد أي القيم ستُجمَع:<syntaxhighlight lang="php"> | |||
$collection = collect([ | $collection = collect([ | ||
سطر 1٬705: | سطر 1٬394: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()take</code>=== | |||
يعيد التابع مجموعةً جديدةً ذاتُ عناصرٍ محددّة:<syntaxhighlight lang="php"> | |||
يعيد التابع | |||
$collection = collect([0, 1, 2, 3, 4, 5]); | $collection = collect([0, 1, 2, 3, 4, 5]); | ||
$chunk = $collection->take(3); | $chunk = $collection->take(3); | ||
$chunk->all(); | $chunk->all(); | ||
سطر 1٬717: | سطر 1٬403: | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك تمرير عدد سالب لأخذ عدد من العناصر من آخر المجموعة:<syntaxhighlight lang="php"> | ||
يمكنك تمرير عدد سالب لأخذ عدد من العناصر من آخر المجموعة: | |||
<syntaxhighlight lang="php"> | |||
$collection = collect([0, 1, 2, 3, 4, 5]); | $collection = collect([0, 1, 2, 3, 4, 5]); | ||
سطر 1٬731: | سطر 1٬414: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()tap</code>=== | |||
يمرّر التابع المجموعة لدالة رد نداء معيّنة. ويسمح لك بالدخول للمجموعة من نقطة محدّدة والقيام بعمل ما على العنصر دون المساس بالمجموعة ككل:<syntaxhighlight lang="php"> | |||
يمرّر التابع | |||
collect([2, 4, 3, 1, 5]) | collect([2, 4, 3, 1, 5]) | ||
سطر 1٬745: | سطر 1٬427: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()times</code>=== | |||
يُنشِئ التابع الساكن مجموعة جديدة عبر استعمال دالة رد نداء عددًا محددًا من المرات:<syntaxhighlight lang="php"> | |||
يُنشِئ التابع الساكن | |||
$collection = Collection::times(10, function ($number) { | $collection = Collection::times(10, function ($number) { | ||
سطر 1٬758: | سطر 1٬439: | ||
</syntaxhighlight> | </syntaxhighlight>يكون هذا التابع مفيدًا عند استعماله مع المصانع لإنشاء نماذج Eloquent:<syntaxhighlight lang="php"> | ||
يكون هذا التابع مفيدًا عند استعماله مع المصانع لإنشاء نماذج Eloquent: | |||
<syntaxhighlight lang="php"> | |||
$categories = Collection::times(3, function ($number) { | $categories = Collection::times(3, function ($number) { | ||
سطر 1٬779: | سطر 1٬457: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()toArray</code>=== | |||
يحوّل التابع المجموعة لمصفوفة PHP. إذا كانت مكوّنات المجموعة نماذج Eloquent، تتحوّل النماذج أيضا لمصفوفات:<syntaxhighlight lang="php"> | يحوّل التابع المجموعة لمصفوفة PHP. إذا كانت مكوّنات المجموعة نماذج Eloquent، تتحوّل النماذج أيضا لمصفوفات:<syntaxhighlight lang="php"> | ||
$collection = collect(['name' => 'Desk', 'price' => 200]); | $collection = collect(['name' => 'Desk', 'price' => 200]); | ||
سطر 1٬793: | سطر 1٬470: | ||
*/ | */ | ||
</syntaxhighlight> | </syntaxhighlight><u>تنبيه</u>: يحوّل <code>toArray</code> كل الكائنات المتداخلة في المجموعة لمصفوفات. إذا أردت الحصول على المصفوفة الخام استعمل التابع <code>all</code> بدلًا منه. | ||
===<code>()toJson</code>=== | |||
<u>تنبيه</u>: يحوّل <code>toArray</code> كل الكائنات المتداخلة في المجموعة لمصفوفات. إذا أردت الحصول على المصفوفة الخام استعمل التابع <code>all</code> بدلًا منه. | يحوّل التابع <code>toJson</code> المجموعة لسلسلة <code>JSON</code>:<syntaxhighlight lang="php"> | ||
=== | |||
يحوّل التابع المجموعة لسلسلة <code>JSON</code>: | |||
<syntaxhighlight lang="php"> | |||
$collection = collect(['name' => 'Desk', 'price' => 200]); | $collection = collect(['name' => 'Desk', 'price' => 200]); | ||
سطر 1٬808: | سطر 1٬481: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()transform</code>=== | |||
يكرّر التابع <code>transform</code> عناصر المجموعة ويستعمل دالة رد نداء مع كل عنصر. يعوّض العناصر في المجموعة بنتائج النداءات:<syntaxhighlight lang="php"> | |||
يكرّر التابع عناصر المجموعة ويستعمل دالة رد نداء مع كل عنصر. يعوّض العناصر في المجموعة بنتائج النداءات:<syntaxhighlight lang="php"> | |||
$collection = collect([1, 2, 3, 4, 5]); | $collection = collect([1, 2, 3, 4, 5]); | ||
سطر 1٬823: | سطر 1٬495: | ||
</syntaxhighlight> | </syntaxhighlight><u>تنبيه</u>: على عكس أغلب توابع المجموعات، يغيّر التابع المجموعة الأصلية. إذا أردت إنشاء مجموعة جديدة فاستعمل التابع <code>map</code> بدلًا منه. | ||
===<code>()union</code>=== | |||
<u>تنبيه</u>: على عكس أغلب توابع المجموعات، يغيّر التابع المجموعة الأصلية. إذا أردت إنشاء مجموعة جديدة فاستعمل التابع <code>map</code> بدلًا منه. | |||
=== | |||
يضيف التابع المصفوفة الممرّرة للمجموعة. إذا احتوت المصفوفة مفاتيح موجودة في المجموعة الأصلية، فستُفضَّل قيم المجموعة الأصلية:<syntaxhighlight lang="php"> | يضيف التابع المصفوفة الممرّرة للمجموعة. إذا احتوت المصفوفة مفاتيح موجودة في المجموعة الأصلية، فستُفضَّل قيم المجموعة الأصلية:<syntaxhighlight lang="php"> | ||
$collection = collect([1 => ['a'], 2 => ['b']]); | $collection = collect([1 => ['a'], 2 => ['b']]); | ||
سطر 1٬839: | سطر 1٬508: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()unique</code>=== | |||
يعيد التابع قيمة فريدة في المجموعة. تحتفظ مجموعة النتيجة بالمفاتيح الأصلية لذا في هذا المثال سنستعمل التابع <code>values</code> لإعادة تعيين المفاتيح لأعداد متتالية:<syntaxhighlight lang="php"> | يعيد التابع قيمة فريدة في المجموعة. تحتفظ مجموعة النتيجة بالمفاتيح الأصلية لذا في هذا المثال سنستعمل التابع <code>values</code> لإعادة تعيين المفاتيح لأعداد متتالية:<syntaxhighlight lang="php"> | ||
$collection = collect([1, 1, 2, 2, 3, 4, 2]); | $collection = collect([1, 1, 2, 2, 3, 4, 2]); | ||
سطر 1٬851: | سطر 1٬519: | ||
</syntaxhighlight> | </syntaxhighlight>عند العمل مع المصفوفات المتداخلة أو الكائنات، يمكن تحديد المفتاح المستعمل لتحديد الفرادة:<syntaxhighlight lang="php"> | ||
عند العمل مع المصفوفات المتداخلة أو الكائنات، يمكن تحديد المفتاح المستعمل لتحديد الفرادة:<syntaxhighlight lang="php"> | |||
$collection = collect([ | $collection = collect([ | ||
سطر 1٬875: | سطر 1٬541: | ||
*/ | */ | ||
</syntaxhighlight> | </syntaxhighlight>يمكنك أيضا تمرير دالة رد النداء الخاصة بك لتحديد الفرادة:<syntaxhighlight lang="php"> | ||
يمكنك أيضا تمرير دالة رد النداء الخاصة بك لتحديد الفرادة:<syntaxhighlight lang="php"> | |||
$unique = $collection->unique(function ($item) { | $unique = $collection->unique(function ($item) { | ||
سطر 1٬895: | سطر 1٬559: | ||
*/ | */ | ||
</syntaxhighlight> | </syntaxhighlight>يستعمل التابع مقارنة غير صارمة أي أن السلاسل النصية التي تحتوي رقمًا تعدّ مساويةً لعددٍ له القيمة الرقمية. استعمل التابع <code>uniqueStrict</code> لمقارنةٍ أكثر صرامةً. | ||
يستعمل التابع مقارنة غير صارمة أي أن السلاسل النصية التي تحتوي رقمًا تعدّ مساويةً لعددٍ له القيمة الرقمية. استعمل التابع <code>uniqueStrict</code> لمقارنةٍ أكثر صرامةً. | ===<code>()uniqueStrict</code>=== | ||
=== | |||
هذا التابع شبيه بالتابع <code>unique</code> لكنه يستعمل مقارنةً صارمةً. | هذا التابع شبيه بالتابع <code>unique</code> لكنه يستعمل مقارنةً صارمةً. | ||
===<code>()unless</code>=== | |||
ينفذ التابع دالة رد النداء الممرَّرة إلا في حالة كان المعامل الأول الممرّر <code>true</code>:<syntaxhighlight lang="php"> | |||
ينفذ التابع | |||
<syntaxhighlight lang="php"> | |||
$collection = collect([1, 2, 3]); | $collection = collect([1, 2, 3]); | ||
سطر 1٬921: | سطر 1٬581: | ||
</syntaxhighlight> | </syntaxhighlight>لعكس وظيفة التابع استعمل التابع <code>when</code>. | ||
===<code>()unwrap</code>=== | |||
لعكس وظيفة التابع استعمل التابع <code>when</code>. | يعيد التابع عناصر المجموعة من القيم الممرّرة عند إمكانية التطبيق:<syntaxhighlight lang="php"> | ||
=== | |||
يعيد التابع | |||
Collection::unwrap(collect('John Doe')); | Collection::unwrap(collect('John Doe')); | ||
سطر 1٬941: | سطر 1٬598: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()values</code>=== | |||
يعيد التابع مجموعةً جديدةً مع إعادة ضبط المفاتيح لأعداد متتالية:<syntaxhighlight lang="php"> | يعيد التابع مجموعةً جديدةً مع إعادة ضبط المفاتيح لأعداد متتالية:<syntaxhighlight lang="php"> | ||
Collection::unwrap(collect('John Doe')); | Collection::unwrap(collect('John Doe')); | ||
سطر 1٬958: | سطر 1٬614: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()when</code>=== | |||
ينفذّ التابع النداء الممرّر عندما تكون قيمة المعامل الأول <code>true</code>:<syntaxhighlight lang="php"> | |||
ينفذّ التابع النداء الممرّر عندما تكون قيمة المعامل الأول <code>true</code>: | |||
<syntaxhighlight lang="php"> | |||
$collection = collect([1, 2, 3]); | $collection = collect([1, 2, 3]); | ||
$collection->when(true, function ($collection) { | $collection->when(true, function ($collection) { | ||
سطر 1٬979: | سطر 1٬632: | ||
</syntaxhighlight> | </syntaxhighlight>لعكس وظيفة <code>when</code> استعمل التابع <code>unless</code>. | ||
===<code>()where</code>=== | |||
لعكس وظيفة when استعمل التابع <code>unless</code>. | |||
=== | |||
يرشِّح التابع المجموعة عبر الزوج المفتاح/القيمة الممرّر:<syntaxhighlight lang="php"> | يرشِّح التابع المجموعة عبر الزوج المفتاح/القيمة الممرّر:<syntaxhighlight lang="php"> | ||
$collection = collect([ | $collection = collect([ | ||
سطر 2٬005: | سطر 1٬655: | ||
*/ | */ | ||
</syntaxhighlight> | </syntaxhighlight>يستعمل التابع مقارنة غير صارمة أي أن السلاسل النصية التي تحتوي رقمًا تعدّ مساويةً لعدد بنفس القيمة الرقمية. استعمل التابع <code>whereStrict</code> لمقارنةٍ أكثر صرامةً. | ||
يستعمل التابع مقارنة غير صارمة أي أن السلاسل النصية التي تحتوي رقمًا تعدّ مساويةً لعدد بنفس القيمة الرقمية. استعمل التابع <code>whereStrict</code> لمقارنةٍ أكثر صرامةً. | ===<code>()whereStrict</code>=== | ||
=== | |||
يشبه هذا التابع عمل <code>where</code> لكنه يستعمل مقارنةً صارمةً. | يشبه هذا التابع عمل <code>where</code> لكنه يستعمل مقارنةً صارمةً. | ||
===<code>()whereIn</code>=== | |||
يرشِّح التابع المجموعة عبر الزوج المفتاح\القيمة المحتواة في المصفوفة الممرّرة:<syntaxhighlight lang="php"> | يرشِّح التابع المجموعة عبر الزوج المفتاح\القيمة المحتواة في المصفوفة الممرّرة:<syntaxhighlight lang="php"> | ||
$collection = collect([ | $collection = collect([ | ||
سطر 2٬033: | سطر 1٬680: | ||
*/ | */ | ||
</syntaxhighlight> | </syntaxhighlight>يستعمل التابع مقارنة غير صارمة أي أن السلاسل النصية التي تحتوي رقمًا تعدّ مساويةً لعددٍ بنفس القيمة الرقمية. استعمل التابع <code>whereInStrict</code> لمقارنةٍ أكثر صرامةً. | ||
يستعمل التابع مقارنة غير صارمة أي أن السلاسل النصية التي تحتوي رقمًا تعدّ مساويةً لعددٍ بنفس القيمة الرقمية. استعمل التابع <code>whereInStrict</code> لمقارنةٍ أكثر صرامةً. | ===<code>()whereInStrict</code>=== | ||
=== | |||
يشبه هذا التابع عمل <code>whereIn</code> لكنه يستعمل مقارنةً صارمة. | يشبه هذا التابع عمل <code>whereIn</code> لكنه يستعمل مقارنةً صارمة. | ||
===<code>()whereInstanceOf</code>=== | |||
يرشِّح التابع المجموعة حسب صنف ممرّر:<syntaxhighlight lang="php"> | |||
يرشِّح التابع | |||
$collection = collect([ | $collection = collect([ | ||
سطر 2٬052: | سطر 1٬696: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()whereNotIn</code>=== | |||
يرشِّح التابع المجموعة حسب زوج المفتاح/القيمة غير مجموعة في المصفوفة الممرّرة:<syntaxhighlight lang="php"> | يرشِّح التابع المجموعة حسب زوج المفتاح/القيمة غير مجموعة في المصفوفة الممرّرة:<syntaxhighlight lang="php"> | ||
$collection = collect([ | $collection = collect([ | ||
سطر 2٬075: | سطر 1٬718: | ||
*/ | */ | ||
</syntaxhighlight> | </syntaxhighlight>يستعمل التابع مقارنة غير صارمة أي أن السلاسل النصية التي تحتوي رقمًا تعدّ مساويةً لعددٍ بنفس القيمة الرقمية. استعمل التابع <code>whereNotInStrict</code> لمقارنةٍ أكثر صرامة. | ||
يستعمل التابع مقارنة غير صارمة أي أن السلاسل النصية التي تحتوي رقمًا تعدّ مساويةً لعددٍ بنفس القيمة الرقمية. استعمل التابع <code>whereNotInStrict</code> لمقارنةٍ أكثر صرامة. | ===<code>()whereNotInStrict</code>=== | ||
=== | |||
يشبه هذا التابع عمل <code>whereNotIn</code> لكنه يستعمل مقارنةً صارمةً. | يشبه هذا التابع عمل <code>whereNotIn</code> لكنه يستعمل مقارنةً صارمةً. | ||
===<code>()wrap</code>=== | |||
يغلِّف التابع الثابت القيمة في مجموعة عند تطبيقه:<syntaxhighlight lang="php"> | |||
يغلِّف التابع | |||
$collection = Collection::wrap('John Doe'); | $collection = Collection::wrap('John Doe'); | ||
سطر 2٬103: | سطر 1٬743: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===<code>()zip</code>=== | |||
يدمج التابع <code>zip</code> قيم المصفوفات الممرّرة في المواضع المناسبة:<syntaxhighlight lang="php"> | يدمج التابع <code>zip</code> قيم المصفوفات الممرّرة في المواضع المناسبة:<syntaxhighlight lang="php"> | ||
$collection = collect(['Chair', 'Desk']); | $collection = collect(['Chair', 'Desk']); | ||
سطر 2٬116: | سطر 1٬755: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
==الرسائل ذات الترتيب العالي== | |||
توفّر المجموعات دعمًا للرسائل ذات الترتيب العالي (higher order messages)، وهي طرق مختصرة لتنفيذ أعمال شائعة على المجموعات. التوابع التي توفر رسائل ذات ترتيب عالي هي: <code>average</code> و <code>avg</code> و <code>contains</code> و <code>each</code> و <code>every</code> و <code>filter</code> و <code>first</code> و <code>flatMap</code> و <code>groupBy</code> و <code>keyBy</code> و <code>map</code> و <code>max</code> و <code>min</code> و <code>partition</code> و <code>reject</code> و <code>sortBy</code> و <code>sortByDesc</code> و <code>sum</code> و <code>unique</code>. | توفّر المجموعات دعمًا للرسائل ذات الترتيب العالي (higher order messages)، وهي طرق مختصرة لتنفيذ أعمال شائعة على المجموعات. التوابع التي توفر رسائل ذات ترتيب عالي هي: <code>average</code> و <code>avg</code> و <code>contains</code> و <code>each</code> و <code>every</code> و <code>filter</code> و <code>first</code> و <code>flatMap</code> و <code>groupBy</code> و <code>keyBy</code> و <code>map</code> و <code>max</code> و <code>min</code> و <code>partition</code> و <code>reject</code> و <code>sortBy</code> و <code>sortByDesc</code> و <code>sum</code> و <code>unique</code>. | ||
يمكن الوصول لكل رسالة ذات ترتيب عالي كخاصية ديناميكية لكائن المجموعة. مثلًا، لنستعمل رسائل التابع <code>each</code> لنداء تابع مع كل عنصر في المجموعة: | يمكن الوصول لكل رسالة ذات ترتيب عالي كخاصية ديناميكية لكائن المجموعة. مثلًا، لنستعمل رسائل التابع <code>each</code> لنداء تابع مع كل عنصر في المجموعة:<syntaxhighlight lang="php"> | ||
<syntaxhighlight lang="php"> | |||
$users = User::where('votes', '>', 500)->get(); | $users = User::where('votes', '>', 500)->get(); | ||
سطر 2٬127: | سطر 1٬764: | ||
</syntaxhighlight> | </syntaxhighlight>بنفس الطريقة، يمكن استعمال رسائل <code>sum</code> لجمع أصوات (votes) مجموعة مستخدمين:<syntaxhighlight lang="php"> | ||
بنفس الطريقة، يمكن استعمال رسائل <code>sum</code> لجمع أصوات (votes) مجموعة مستخدمين:<syntaxhighlight lang="php"> | |||
$users = User::where('group', 'Development')->get(); | $users = User::where('group', 'Development')->get(); | ||
سطر 2٬135: | سطر 1٬770: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
* [https://laravel.com/docs/5.6/collections توثيق Laravel الرسمي | ==مصادر== | ||
[[تصنيف:Laravel]] | *[https://laravel.com/docs/5.6/collections صفحة Collections في توثيق Laravel الرسمي.]<noinclude>{{DISPLAYTITLE:المجموعات (Collections) في Laravel}}</noinclude> | ||
[[تصنيف:Laravel Digging deeper]] | [[تصنيف:Laravel|{{SUBPAGENAME}}]] | ||
[[تصنيف:Laravel Digging deeper|{{SUBPAGENAME}}]] |
المراجعة الحالية بتاريخ 14:05، 24 أكتوبر 2018
مقدمة
يوفر الصنف Illuminate\Support\Collection
غلافًا ملائمًا و مساعدًا على العمل مع مصفوفات البيانات. مثلًا، تفقد الشيفرة الموالية إذ سنستعمل المساعد collect
لإنشاء نسخة Collection
جديدة من المصفوفة، ننفذ الدالة strtoupper
مع كل عنصر، ثم نحذف كل العناصر الفارغة:
$collection = collect(['taylor', 'abigail', null])->map(function ($name) {
return strtoupper($name);
}) ->reject(function ($name) {
return empty($name);
});
كما ترى، تسمح الدالة بسلسلة توابعها لتنفيذِ تخطيطِ دقيق و التحكم في حجم المصفوفة قيد العمل. بشكل عام، المجموعات غير قابلة للتغيير، أي أن كل تابع collect
يعيد نسخة من كائن مجموعة جديد تمامًا.
إنشاء المجموعات
كما ذُكر سابقًا، يعيد التابع المساعد collect
نسخة من كائن Illuminate\Support\Collection
جديد لكل مصفوفة. لذا، يمكننا إنشاء مجموعة بسهولة
$collection = collect([1, 2, 3]);
ملاحظة: نتائج طلبات Eloquent تكون دائمًا على شكل كائن Collection
.
تمديد المجموعات
المجموعات قابلة للتمديد، مما يسمح لك بإضافة توابع أخرى للصنف Collection
في وقت التشغيل. مثلًا، الشيفرة التالية تضيف التابع toUpper
إلى الصنف Collection
:
use Illuminate\Support\Str;
Collection::macro('toUpper', function () {
return $this->map(function ($value) {
return Str::upper($value);
});
});
$collection = collect(['first', 'second']);
$upper = $collection->toUpper();
// ['FIRST', 'SECOND']
في العادة، عليك ذكر الإضافات للصنف Collection
في مزود الخدمات.
التوابع المتاحة
في بقية هذا التوثيق، سنناقش كل تابع متوافر في الصنف Collection
. تذكر أنّ كل التوابع يمكن سلسلتها معًا لمعالجة المصفوفة بيسر. بالإضافة ألى ذلك، تقريبًا كل التوابع تعيد نسخة جديدة من الكائن Collection
مما يحافظ على المجموعة الأصلية عند الحاجة:
()all
يعيد التابع المصفوفة المقصودة على شكل مجموعة:
collect([1, 2, 3])->all();
// [1, 2, 3]
()average
اسم بديل للتابع avg
.
()avg
يعيد التابع قيمة المتوسط الحسابي للمفتاح الممرّر:
$average = collect([['foo' => 10], ['foo' => 10], ['foo' => 20], ['foo' => 40]])->avg('foo');
// 20
$average = collect([1, 1, 2, 4])->avg();
// 2
()chunk
يقسم التابع المجموعة لعدة مجموعات أصغر بحجم معين:
$collection = collect([1, 2, 3, 4, 5, 6, 7]);
$chunks = $collection->chunk(4);
$chunks->toArray();
// [[1, 2, 3, 4], [5, 6, 7]]
هذا التابع مفيد خاصة في الواجهات عند العمل مع نظام شبكي "grid" مثل Bootstrap
. تخيل أنك تريد عرض مجموعة من نماذج Eloquent في شبكة:
@foreach ($products->chunk(3) as $chunk)
@foreach ($chunk as $product)
{{$product->name }}
@endforeach
@endforeach
()collapse
يُسقط التابع مجموعة من المصفوفات في مجموعة واحدة ذات بعد واحد:
$collection = collect([[1, 2, 3], [4, 5, 6], [7, 8, 9]]);
$collapsed = $collection->collapse();
$collapsed->all();
// [1, 2, 3, 4, 5, 6, 7, 8, 9]
()combine
يدمج التابع مفاتيح المجموعة مع قيم من مجموعة أو مصفوفة أخرى:
$collection = collect(['name', 'age']);
$combined = $collection->combine(['George', 29]);
$combined->all();
// ['name' => 'George', 'age' => 29]
()concat
يضيف التابع المصفوفة الممررة أو قيم المجموعة المُمَرَّرة لآخر المجموعة:
$collection = collect(['John Doe']);
$concatenated = $collection->concat(['Jane Doe'])->concat(['name' => 'Johnny Doe']);
$concatenated->all();
// ['John Doe', 'Jane Doe', 'Johnny Doe']
()contains
يحدد التابع إذا كانت المجموعة تحتوي على عنصرٍ محدِّد أم لا:
$collection = collect(['name' => 'Desk', 'price' => 100]);
$collection->contains('Desk');
// true
$collection->contains('New York');
// false
يمكنك أيضًا تمرير زوجٍ من المفتاح/القيمة إلى التابع الذي سيحدد إذا كان الثنائي موجودًا أم لا:
$collection = collect([
['product' => 'Desk', 'price' => 200],
['product' => 'Chair', 'price' => 100],
]);
$collection->contains('product', 'Bookcase');
// false
أخيرًا، يمكنك تمرير دالة رد نداء إلى التابع contains
لتقوم بعملية التحقق من وجود القيمة بنفسك:
$collection = collect([1, 2, 3, 4, 5]);
$collection->contains(function ($value, $key) {
return $value > 5;
});
// false
يقوم التابع بمقارنة بسيطة، أي أن سلسلة المحارف التي تحتوي على رقم تُعدّ مساويةً لعدد صحيحٍ بنفس القيمة الرقمية. استعمل التابع containsStrict
لمقارنة أكثر صرامةً.
()containsStrict
نفس الوظيفة التابع لكنها تستعمل مقارنةً صارمةً (strict).
()count
يعيد التابع عدد عناصر المجموعة:
$collection = collect([1, 2, 3, 4]);
$collection->count();
// 4
()crossJoin
يقوم التابع بوصل تقاطعي بين قيم المجموعة والمصفوفة الممرّرة، ويعيد جداءً ديكارتيًا بكل المبادلات الممكنة:
$collection = collect([1, 2]);
$matrix = $collection->crossJoin(['a', 'b']);
$matrix->all();
/*
[
[1, 'a'],
[1, 'b'],
[2, 'a'],
[2, 'b'],
]
*/
$collection = collect([1, 2]);
$matrix = $collection->crossJoin(['a', 'b'], ['I', 'II']);
$matrix->all();
/*
[
[1, 'a', 'I'],
[1, 'a', 'II'],
[1, 'b', 'I'],
[1, 'b', 'II'],
[2, 'a', 'I'],
[2, 'a', 'II'],
[2, 'b', 'I'],
[2, 'b', 'II'],
]
*/
()dd
يطبع التابع عناصر المجموعة وينهي تنفيذ السكربت:
$collection = collect(['John Doe', 'Jane Doe']);
$collection->dd();
/*
Collection {
#items: array:2 [
0 => "John Doe"
1 => "Jane Doe"
]
}
*/
إذا لم ترد إنهاء السكربت، فاستعمل التابع dump
بدلًا من dd
.
()diff
يقارن التابع المجموعة بمجموعة أخرى أو بمصفوفة PHP عادية اعتمادًا على قيمها. يعيد هذا التابع قيم المجموعة الأصلية غير الموجودة في المجموعة الممرّرة:
$collection = collect([1, 2, 3, 4, 5]);
$diff = $collection->diff([2, 4, 6, 8]);
$diff->all();
// [1, 3, 5]
()diffAssoc
يقارن التابع المجموعة بمجموعة أخرى أو بمصفوفة PHP بالاعتماد على المفاتيح والقيم. يعيد هذا التابع أزواج المفتاح/القيمة من المجموعة الأصلية غير الموجودة في المجموعة الممررة:
$collection = collect([
'color' => 'orange',
'type' => 'fruit',
'remain' => 6
]);
$diff = $collection->diffAssoc([
'color' => 'yellow',
'type' => 'fruit',
'remain' => 3,
'used' => 6
]);
$diff->all();
// ['color' => 'orange', 'remain' => 6]
()diffKeys
يقارن هذا التابع المجموعة بمجموعة أخرى أو بمصفوفة PHP بالإرتكاز على المفاتيح، يعيد هذا التابع أزواج المفتاح/القيمة من المجموعة الأصلية غير الموجودة في المجموعة الممرّرة:
$collection = collect([
'one' => 10,
'two' => 20,
'three' => 30,
'four' => 40,
'five' => 50,
]);
$diff = $collection->diffKeys([
'two' => 2,
'four' => 4,
'six' => 6,
'eight' => 8,
]);
$diff->all();
// ['one' => 10, 'three' => 30, 'five' => 50]
()dump
يطبع التابع عناصر المجموعة:
$collection = collect(['John Doe', 'Jane Doe']);
$collection->dump();
/*
Collection {
#items: array:2 [
0 => "John Doe"
1 => "Jane Doe"
]
}
*/
إذا أردت إيقاف تنفيذ السكربت بعد تفريغ المجموعة فاستعمل التابع dd
.
()each
يكرّر التابع عناصر المجموعة واحدًا بواحد ويمرّرها لدالة رد نداء:
$collection->each(function ($item, $key) {
//
});
إذا أردت إيقاف التكرار، أعد القيمة false
من دالة رد النداء:
$collection->each(function ($item, $key) {
if (/* شرط إيقاف */) {
return false;
}
});
()eachSpread
يكرّّر التابع عناصر المجموعة ويمرّر كل عنصر متداخل لدالة رد النداء:
$collection = collect([['John Doe', 35], ['Jane Doe', 33]]);
$collection->eachSpread(function ($name, $age) {
//
});
يمكنك إيقاف التكرار بإعادة القيمة false
من دالة رد النداء.
$collection->eachSpread(function ($name, $age) {
return false;
});
()every
يمكن استعمال التابع للتأكد من أن كل عناصر المجموعة تحقق شرطًا معينًا:
collect([1, 2, 3, 4])->every(function ($value, $key) {
return $value > 2;
});
// false
()except
يعيد التابع كل عناصر المجموعة باستثناء العناصر بالمفاتيح المحدَّدة:
$collection = collect(['product_id' => 1, 'price' => 100, 'discount' => false]);
$filtered = $collection->except(['price', 'discount']);
$filtered->all();
// ['product_id' => 1]
لعكس وظيفة except
، انظر التابع only
.
()filter
يرشِّح التابع عناصر المجموعة ويُبقي فقط العناصر التي تحقق شرطًا معينًا:
$collection = collect([1, 2, 3, 4]);
$filtered = $collection->filter(function ($value, $key) {
return $value > 2;
});
$filtered->all();
// [3, 4]
إذا لم توفّر نداء للتابع، يحذف filter
كل العناصر المساوية للقيمة false
:
$collection = collect([1, 2, 3, null, false, , 0, []]);
$collection->filter()->all();
// [1, 2, 3]
لعكس وظيفة filter
انظر التابع reject
.
()first
يرجع التابع العنصر الأول من المجموعة الذي يحقق شرطًا معينًا:
collect([1, 2, 3, 4])->first(function ($value, $key) {
return $value > 2;
}); // 3
يمكنك أيضًا استدعاء التابع first
دون معامل، وسيعيد العنصر الأول من المجموعة، وإذا كانت المجموعة فارغةً، فستعاد القيمة null
:
collect([1, 2, 3, 4])->first();
// 1
()firstWhere
يعيد التابع العنصر الأول من المجموعة الموافق لزوج المفتاح/القيمة الممرّر:
$collection = collect([
['name' => 'Regena', 'age' => 12],
['name' => 'Linda', 'age' => 14],
['name' => 'Diego', 'age' => 23],
['name' => 'Linda', 'age' => 84],
]);
$collection->firstWhere('name', 'Linda');
// ['name' => 'Linda', 'age' => 14]
يمكن أيضًا استعمال التابع مع عامل مقارنة:
$collection->firstWhere('age', '>=', 18);
// ['name' => 'Diego', 'age' => 23]
()flatMap
ينفذ التابع حلقة تكرار في المجموعة، فيمرر قيمة كل تكرار لنداء معين. يمكن للنداء تغيير العنصر وإرجاعه وبالتالي يكوّن مجموعةً جديدة من العناصر المغيَّرة. ثم تُسطَّح المجموعة حسب مستواها:
$collection = collect([
['name' => 'Sally'],
['school' => 'Arkansas'],
['age' => 28]
]);
$flattened = $collection->flatMap(function ($values) {
return array_map('strtoupper', $values);
});
$flattened->all();
// ['name' => 'SALLY', 'school' => 'ARKANSAS', 'age' => '28'];
()flatten
يُسطِّح التابع مجموعة متعددة الأبعاد لمجموعة ذات بعد واحد:
$collection = collect(['name' => 'taylor', 'languages' => ['php', 'javascript']]);
$flattened = $collection->flatten();
$flattened->all();
// ['taylor', 'php', 'javascript'];
يمكنك أيضًا تمرير معامل لضبط عمق التسطيح:
$collection = collect([
'Apple' => [
['name' => 'iPhone 6S', 'brand' => 'Apple'],
],
'Samsung' => [
['name' => 'Galaxy S7', 'brand' => 'Samsung']
],
]);
$products = $collection->flatten(1);
$products->values()->all();
/*
[
['name' => 'iPhone 6S', 'brand' => 'Apple'],
['name' => 'Galaxy S7', 'brand' => 'Samsung'],
]
في هذا المثال، سيتسبب عدم توفير عمق في تسطيح المصفوفات الداخلية لتصبح النتيجة ['iPhone 6S', 'Apple', 'Galaxy S7', 'Samsung']
. مما يوفّر مستوى عمق يسمح بتحديد مستوى التداخل الذي سيتم تسطيحه.
()flip
يُبدِّل التابع المفتاح بقيمته:
$collection = collect(['name' => 'taylor', 'framework' => 'laravel']);
$flipped = $collection->flip();
$flipped->all();
// ['taylor' => 'name', 'laravel' => 'framework']
()forget
يحذف التابع عنصرًا من المجموعة باستخدام مفتاحه:
$collection = collect(['name' => 'taylor', 'framework' => 'laravel']);
$collection->forget('name');
$collection->all();
// ['framework' => 'laravel']
تنبيه: على عكس جل توابع المجموعات، لا يعيد forget
مجموعةً جديدةً بل يغيّر في المجموعة التي استدعي هذا التابع عليها.
()forPage
يعيد التابع مجموعة تحتوي العناصر الموجودة في رقم الصفحة الممرّر. يقبل التابع رقم صفحة كمعامل أول وعدد العناصر التي يجب إظهارها في الصفحة كمعامل ثاني:
$collection = collect([1, 2, 3, 4, 5, 6, 7, 8, 9]);
$chunk = $collection->forPage(2, 3);
$chunk->all();
// [4, 5, 6]
()get
يعيد التابع قيمة العنصر ذي المفتاح المُمرَّر إلى التابع. إذا كان المفتاح غير موجود فستعاد القيمة null
:
$collection = collect(['name' => 'taylor', 'framework' => 'laravel']);
$value = $collection->get('name');
// taylor
يمكنك تمرير قيمة أولية اختيارية كمعامل ثاني:
$collection = collect(['name' => 'taylor', 'framework' => 'laravel']);
$value = $collection->get('foo', 'default-value');
// default-value
يمكنك حتى تمرير دالة رد نداء. تُعاد القيمة المُعادة من دالة رد النداء في حال عدم وجود المفتاح:
$collection->get('email', function () {
return 'default-value';
});
// default-value
()groupBy
يُجمِّع التابع العناصر حسب قيمة المفتاح الممرّر إلى التابع:
$collection = collect([
['account_id' => 'account-x10', 'product' => 'Chair'],
['account_id' => 'account-x10', 'product' => 'Bookcase'],
['account_id' => 'account-x11', 'product' => 'Desk'],
]);
$grouped = $collection->groupBy('account_id');
$grouped->toArray();
/*
[
'account-x10' => [
['account_id' => 'account-x10', 'product' => 'Chair'],
['account_id' => 'account-x10', 'product' => 'Bookcase'],
],
'account-x11' => [
['account_id' => 'account-x11', 'product' => 'Desk'],
],
]
*/
بدل تمرير سلسلة محارف key
، يمكنك تمرير دالة رد نداء التي يجب أن تعيد القيمة التي تريد أن تكون مفتاح التجميع:
$grouped = $collection->groupBy(function ($item, $key) {
return substr($item['account_id'], -3);
});
$grouped->toArray();
/*
[
'x10' => [
['account_id' => 'account-x10', 'product' => 'Chair'],
['account_id' => 'account-x10', 'product' => 'Bookcase'],
],
'x11' => [
['account_id' => 'account-x11', 'product' => 'Desk'],
],
]
*/
يمكن تمرير عدة معايير تجميع كمصفوفة، يُطبّق كل عنصر من المصفوفة على مستوى العمق الملائم في مصفوفة متعددة الأبعاد:
$data = new Collection([
10 => ['user' => 1, 'skill' => 1, 'roles' => ['Role_1', 'Role_3']],
20 => ['user' => 2, 'skill' => 1, 'roles' => ['Role_1', 'Role_2']],
30 => ['user' => 3, 'skill' => 2, 'roles' => ['Role_1']],
40 => ['user' => 4, 'skill' => 2, 'roles' => ['Role_2']],
]);
$result = $data->groupBy([
'skill',
function ($item) {
return $item['roles'];
},
], $preserveKeys = true);
/* [
1 => [
'Role_1' => [
10 => ['user' => 1, 'skill' => 1, 'roles' => ['Role_1', 'Role_3']],
20 => ['user' => 2, 'skill' => 1, 'roles' => ['Role_1', 'Role_2']],
],
'Role_2' => [
20 => ['user' => 2, 'skill' => 1, 'roles' => ['Role_1', 'Role_2']],
],
'Role_3' => [
10 => ['user' => 1, 'skill' => 1, 'roles' => ['Role_1', 'Role_3']],
],
],
2 => [
'Role_1' => [
30 => ['user' => 3, 'skill' => 2, 'roles' => ['Role_1']],
],
'Role_2' => [
40 => ['user' => 4, 'skill' => 2, 'roles' => ['Role_2']],
],
],
];
*/
()has
يحدد التابع إذا كان المفتاح موجودًا في المجموعة أم لا:
$collection = collect(['account_id' => 1, 'product' => 'Desk']);
$collection->has('product');
// true
()implode
يضم التابع عناصر المجموعة في سلسلة حرفية. تعتمد التوابع على نوع العناصر في المجموعة. إذا كانت المجموعة تحتوي مصفوفات أو كائنات، يجب تمرير مفتاح الخاصيات التي تريد ضمّها وعلامة الربط "glue" الذي تريد استعماله بين القيم:
$collection = collect([
['account_id' => 1, 'product' => 'Desk'],
['account_id' => 2, 'product' => 'Chair'],
]);
$collection->implode('product', ', ');
// Desk, Chair
إذا كانت المجموعة تحتوي سلاسل نصية أو قيمًا رقميةً بسيطةً، فمرّر علامة الربط فقط كمعامل إلى التابع:
collect([1, 2, 3, 4, 5])->implode('-');
// '1-2-3-4-5'
()intersect
يحذف التابع أي قيمة في المجموعة الأصلية غير موجودة في المجموعة أو المصفوفة الممرّرة. تحافظ المجموعة النهائية على مفاتيح المجموعة الأصلية:
$collection = collect(['Desk', 'Sofa', 'Chair']);
$intersect = $collection->intersect(['Desk', 'Chair', 'Bookcase']);
$intersect->all();
// [0 => 'Desk', 2 => 'Chair']
()intersectByKeys
يحذف التابع أي مفتاح من المجموعة الأصلية غير موجود في المجموعة أو المصفوفة الممرّرة:
$collection = collect([
'serial' => 'UX301', 'type' => 'screen', 'year' => 2009
]);
$intersect = $collection->intersectByKeys([
'reference' => 'UX404', 'type' => 'tab', 'year' => 2011
]);
$intersect->all();
// ['type' => 'screen', 'year' => 2009]
()isEmpty
يعيد التابع القيمة true
إذا كانت المجموعة فارغة وإلا فسيعيد false
:
collect([])->isEmpty();
// true
()isNotEmpty
يعيد التابع القيمة true
إذا لم تكن المجموعة فارغة، وإلا فسيعيد false
:
collect([])->isNotEmpty();
// false
()keyBy
يضيف التابع مفاتيح للمجموعة، إذا وُجد أكثر من عنصر بنفس المفتاح، فسيضاف الأخير فقط إلى المجموعة الجديدة:
$collection = collect([
['product_id' => 'prod-100', 'name' => 'Desk'],
['product_id' => 'prod-200', 'name' => 'Chair'],
]);
$keyed = $collection->keyBy('product_id');
$keyed->all();
/*
[
'prod-100' => ['product_id' => 'prod-100', 'name' => 'Desk'],
'prod-200' => ['product_id' => 'prod-200', 'name' => 'Chair'],
]
*/
يمكنك تمرير نداء للتابع. يجب أن يعيد النداء القيمة التي ستستعمل كمفتاح للمجموعة:
$keyed = $collection->keyBy(function ($item) {
return strtoupper($item['product_id']);
});
$keyed->all();
/*
[
'PROD-100' => ['product_id' => 'prod-100', 'name' => 'Desk'],
'PROD-200' => ['product_id' => 'prod-200', 'name' => 'Chair'],
]
*/
()keys
يعيد التابع مجموعة متكونة من كل المفاتيح:
$collection = collect([
'prod-100' => ['product_id' => 'prod-100', 'name' => 'Desk'],
'prod-200' => ['product_id' => 'prod-200', 'name' => 'Chair'],
]);
$keys = $collection->keys();
$keys->all();
// ['prod-100', 'prod-200']
()last
يعيد التابع العنصر الأخير الذي يحقق شرطًا معينًا. إذا كانت المجموعة فارغةً، فسيعيد التابع القيمة null
: collect([1, 2, 3, 4])->last();
// 4
()macro
يسمح التابع بإضافة توابع للصنف Collection
في وقت التشغيل. راجع التوثيق حول تمديد المجموعات لمزيد من المعلومات.
()make
يُنشِئ التابع نسخة مجموعة جديدة. راجع قسم إنشاء المجموعات.
()map
يكرّر التابع عناصر المجموعة و يمرّر كل قيمة لدالة رد نداء معيّنة. يمكن لدالة رد اللنداء تغيير العنصر وإعادته، وبالتالي تكوين مجموعة جديدة من العناصر المغيّرة:
$collection = collect([1, 2, 3, 4, 5]);
$multiplied = $collection->map(function ($item, $key) {
return $item * 2;
});
$multiplied->all();
// [2, 4, 6, 8, 10
تنبيه: كأغلب توابع المجموعات، يعيد map
مجموعة جديدة ولا يغير المجموعة الأصلية. إذا أردت تغيير المجموعة الأصلية فاستعمل التابع transform
.
()mapInfo
يكرّر التابع المجموعة وينشِئ نسخةً جديدةً من صنف معين عبر تمرير القيمة للتابع الباني للصنف:
class Currency {
/**
* صناعة مثيل جديد.
*
* @param string $code
* @return void
*/
function __construct(string $code)
{
$this->code = $code;
}
}
$collection = collect(['USD', 'EUR', 'GBP']);
$currencies = $collection->mapInto(Currency::class);
$currencies->all();
// [Currency('USD'), Currency('EUR'), Currency('GBP')]
()mapSpread
يكرّر التابع عناصر المجموعة ويمرّر كل عنصر متداخل لدالة رد نداء. يمكن لدالة رد النداء تغيير العنصر وإعادته، وبالتالي تكوين مجموعة جديدة من العناصر المغيرة:
$collection = collect([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]);
$chunks = $collection->chunk(2);
$sequence = $chunks->mapSpread(function ($odd, $even) {
return $odd + $even;
});
$sequence->all();
// [1, 5, 9, 13, 17]
()mapToGroups
يُجمّع التابع عناصر المجموعة باستخدام دالة رد النداء المعيّنة. تعيد دالة رد النداء مصفوفة تجميعية تحتوي زوج المفتاح/القيمة واحد، وبالتالي تكوين مجموعة من القيم المجمَّعة:
$collection = collect([
[
'name' => 'John Doe',
'department' => 'Sales',
],
[
'name' => 'Jane Doe',
'department' => 'Sales',
],
[
'name' => 'Johnny Doe',
'department' => 'Marketing',
]
]);
$grouped = $collection->mapToGroups(function ($item, $key) {
return [$item['department'] => $item['name']];
});
$grouped->toArray();
/*
[
'Sales' => ['John Doe', 'Jane Doe'],
'Marketing' => ['Johhny Doe'],
]
*/
$grouped->get('Sales')->all();
// ['John Doe', 'Jane Doe']
()mapWithKeys
يكرّر التابع المجموعة ويمرّر القيم لدالة رد نداء معيّنة. يعيد التابع مصفوفة تجميعية تحتوي زوج المفتاح/القيمة واحد:
$collection = collect([
[
'name' => 'John',
'department' => 'Sales',
'email' => 'john@example.com'
],
[
'name' => 'Jane',
'department' => 'Marketing',
'email' => 'jane@example.com'
]
]);
$keyed = $collection->mapWithKeys(function ($item) {
return [$item['email'] => $item['name']];
});
$keyed->all();
/*
[
'john@example.com' => 'John',
'jane@example.com' => 'Jane',
]
*/
()max
يعيد التابع القيمة القصوى في لمفتاح معين:
$max = collect([['foo' => 10], ['foo' => 20]])->max('foo');
// 20 $max = collect([1, 2, 3, 4, 5])->max();
// 5
()median
يعيد التابع القيمة الوسطية للمفتاح المعين:
$median = collect([['foo' => 10], ['foo' => 10], ['foo' => 20], ['foo' => 40]])->median('foo');
// 15
$median = collect([1, 1, 2, 4])->median();
// 1.5
()merge
يدمج التابع المصفوفة أو المجموعة الممرّرة مع المجموعة الأصلية، تلغي القيم الممرّرة القيم الأصلية:
$collection = collect(['product_id' => 1, 'price' => 100]);
$merged = $collection->merge(['price' => 200, 'discount' => false]);
$merged->all();
// ['product_id' => 1, 'price' => 200, 'discount' => false]
إذا كانت المفاتيح الممرّرة رقمية، تضاف القيم في آخر المجموعة:
$collection = collect(['Desk', 'Chair']);
$merged = $collection->merge(['Bookcase', 'Door']);
$merged->all();
// ['Desk', 'Chair', 'Bookcase', 'Door']
()min
يعيد التابع القيمة الأصغر لمفتاح معين:
$min = collect([['foo' => 10], ['foo' => 20]])->min('foo');
// 10
$min = collect([1, 2, 3, 4, 5])->min();
// 1
()mode
يعيد التابع قيمة المنوال لمفتاح معين:
$mode = collect([['foo' => 10], ['foo' => 10], ['foo' => 20], ['foo' => 40]])->mode('foo');
// [10]
$mode = collect([1, 1, 2, 4])->mode();
// [1]
()nth
ينشِئ التابع مجموعةً جديدةً متكونةً من كل عنصر بعد n عناصر
$collection = collect(['a', 'b', 'c', 'd', 'e', 'f']);
$collection->nth(4);
// ['a', 'e']
يمكنك تمرير موضع البداية كمعامل ثاني:
$collection->nth(4, 1);
// ['b', 'f']
()only
يعيد التابع العناصر في المجموعة ذات المفاتيح الممرّرة:
$collection->nth(4, 1);
// ['b', 'f']
لعكس وظيفة only
، استعمل التابع expect
.
()pad
يملأ التابع المصفوفة بالقيمة الممرّرة حتى تصل للحجم المحدد. يشبه هذا التابع دالة array_pad
في PHP.
$collection = collect(['A', 'B', 'C']);
$filtered = $collection->pad(5, 0);
$filtered->all();
// ['A', 'B', 'C', 0, 0]
$filtered = $collection->pad(-5, 0);
$filtered->all();
// [0, 0, 'A', 'B', 'C']
()partition
يمكن استعمال التابع مع الدالة list
في PHP لتفريق العناصر التي تجتاز شرط صحة عن البقية:
$collection = collect([1, 2, 3, 4, 5, 6]);
list($underThree, $equalOrAboveThree) = $collection->partition(function ($i) {
return $i < 3;
});
$underThree->all();
// [1, 2]
$equalOrAboveThree->all();
// [3, 4, 5, 6]
pipe()
يمرّر التابع المجموعة لنداء معين ويعيد نتيجة دالة رد النداء:
$collection = collect([1, 2, 3]);
$piped = $collection->pipe(function ($collection) {
return $collection->sum();
});
// 6
()pluck
يسترجع التابع كل القيم من مفتاح ممرّر:
$collection = collect([
['product_id' => 'prod-100', 'name' => 'Desk'],
['product_id' => 'prod-200', 'name' => 'Chair'],
]);
$plucked = $collection->pluck('name');
$plucked->all();
// ['Desk', 'Chair']
يمكنك أيضا تحديد مفاتيح المجموعة الناتجة:
$plucked = $collection->pluck('name', 'product_id');
$plucked->all();
// ['prod-100' => 'Desk', 'prod-200' => 'Chair']
إذا وُجدت مفاتيح متشابهة، فسيضاف العنصر الأخير الموافق للمفتاح:
$collection = collect([
['brand' => 'Tesla', 'color' => 'red'],
['brand' => 'Pagani', 'color' => 'white'],
['brand' => 'Tesla', 'color' => 'black'],
['brand' => 'Pagani', 'color' => 'orange'],
]);
$plucked = $collection->pluck('color', 'brand');
$plucked->all();
// ['Tesla' => 'black', 'Pagani' => 'orange']
()pop
يحذف التابع العنصر الأخير من المجموعة ويعيده:
$collection = collect([1, 2, 3, 4, 5]);
$collection->pop();
// 5
$collection->all();
// [1, 2, 3, 4]
()prepend
يضيف التابع عناصر في أول المجموعة:
$collection = collect([1, 2, 3, 4, 5]);
$collection->prepend(0);
$collection->all();
// [0, 1, 2, 3, 4, 5]
يمكنك تمرير معامل ثاني لتحديد مفتاح العناصر المضافة:
$collection = collect(['one' => 1, 'two' => 2]);
$collection->prepend(0, 'zero');
$collection->all();
// ['zero' => 0, 'one' => 1, 'two' => 2]
()pull
يحذف التابع عنصرًا من المجموعة ويعيده وذلك باستعمال مفتاحه:
$collection = collect(['product_id' => 'prod-100', 'name' => 'Desk']);
$collection->pull('name');
// 'Desk'
$collection->all();
// ['product_id' => 'prod-100']
()push
يضيف التابع عنصرًا في آخر المجموعة:
$collection = collect([1, 2, 3, 4]);
$collection->push(5);
$collection->all();
// [1, 2, 3, 4, 5]
()put
يضع التابع المفتاح والقيمة في المجموعة:
$collection = collect(['product_id' => 1, 'name' => 'Desk']);
$collection->put('price', 100);
$collection->all();
// ['product_id' => 1, 'name' => 'Desk', 'price' => 100]
()random
يعيد التابع عنصرًا عشوائيًا من المجموعة:
$collection = collect([1, 2, 3, 4, 5]);
$collection->random();
// 4 - (retrieved randomly)
يمكنك اختيار تمرير عدد للتابع لتحديد عدد العناصر التي تريد إعادتها عشوائيًا. يعيد التابع مجموعة في حال تمرير عدد العناصر المطلوبة:
$random = $collection->random(3);
$random->all();
// [2, 4, 5] - (retrieved randomly)
إذا كان عدد العناصر في المجموعة أقل من المطلوب فسيُطلق التابع الاستثناء InvalidArgumentException
.
()reduce
يقلص التابع المجموعة لعنصر واحد بتمرير نتيجة كل تكرار نداء للتكرار الموالي:
$collection = collect([1, 2, 3]);
$total = $collection->reduce(function ($carry, $item) {
return $carry + $item;
});
// 6
قيمة carry$
في التكرار الأول null
، لكن بإمكانك تمرير قيمة الأولية يرجعها التابع بدل null
كمعامل ثاني للتابع:
$collection->reduce(function ($carry, $item) {
return $carry + $item;
}, 4);
// 10
()reject
يُستعمل التابع لترشيح المجموعة باستعمال دالة رد نداء معينة. يجب أن تعيد دالة رد النداء القيمة true
ليُحذف العنصر من المجموعة الناتجة:
$collection = collect([1, 2, 3, 4]);
$filtered = $collection->reject(function ($value, $key) {
return $value > 2;
});
$filtered->all();
// [1, 2]
لعكس وظيفة reject
، انظر التابع filter
.
()reverse
يعكس التابع ترتيب عناصر المجموعة محافظًا على المفاتيح الأصلية:
$collection = collect(['a', 'b', 'c', 'd', 'e']);
$reversed = $collection->reverse();
$reversed->all();
/*
[
4 => 'e',
3 => 'd',
2 => 'c',
1 => 'b',
0 => 'a',
]
*/
()search
يبحث التابع عن قيمة معينة ويعيد مفتاحها. إذا لم توجد القيمة المطلوبة فسيعيد التابع القيمة false
:
$collection = collect([2, 4, 6, 8]);
$collection->search(4);
// 1
يقارن هذا التابع مقارنة غير صارمة أي أن سلسلةً نصيةً تحتوي على رقمٍ تعدّ مساويةً للقيمة الرقمية. لاستعمال مقارنة صارمة، مرّر true
كمعامل ثاني إلى التابع:
$collection->search('4', true);
// false
بشكلٍ بديل، يمكنك تمرير دالة رد النداء الخاصة بك للبحث عن العنصر الأول الذي يحقق شرط الصحة الذي تحدّده:
$collection->search(function ($item, $key) {
return $item > 5;
});
// 2
()shift
يحذف التابع ويعيد العنصر الأول من المجموعة
$collection = collect([1, 2, 3, 4, 5]);
$collection->shift();
// 1
$collection->all();
// [2, 3, 4, 5]
()shuffle
يخلط التابع العناصر عشوائيًا:
$collection = collect([1, 2, 3, 4, 5]);
$shuffled = $collection->shuffle();
$shuffled->all();
// [3, 2, 5, 1, 4] - (generated randomly)
()slice
يعيد التابع قطعة من المجموعة بدءًا من مكان محدّد:
$collection = collect([1, 2, 3, 4, 5, 6, 7, 8, 9, 10]);
$slice = $collection->slice(4);
$slice->all();
// [5, 6, 7, 8, 9, 10]
إذا أردت تحديد حجم القطعة مرّر الحجم كمعامل ثاني للتابع:
$slice = $collection->slice(4, 2);
$slice->all();
// [5, 6]
تحافظ القطعة على المفاتيح الأصلية، إذا لم ترد الحفاظ عليها فاستخدم التابع values
لإعادة تسميتها.
()sort
يُرتِّب التابع المجموعة. تحافظ المجموعة الناتجة على المفاتيح الأصلية لذا سنستعمل في المثال التابع values
لإعادة تعيين المفاتيح لأعداد متتالية:
$collection = collect([5, 3, 1, 2, 4]);
$sorted = $collection->sort();
$sorted->values()->all();
// [1, 2, 3, 4, 5]
إذا احتجت ترتيبًا أكثر تعقيدًا، يمكنك تمرير دالة رد نداء للمنطق المتبع في طريقة الترتيب الخاصة بك. راجع توثيق الدالة uasort
في PHP وهي طريقة الترتيب الذي يعتمدها التابع sort
وراء الكواليس.
ملاحظة: إذا احتجت إلى ترتيب مجموعة مصفوفات متداخلة أو كائنات فراجع التابعين sortBy
و sortByDesc
.
()sortBy
يرتب التابع المجموعة حسب مفتاح ممرّر. تحافظ المجموعة المرتَّبة على المفاتيح الأصلية لذا في هذا المثال سنستعمل التابع values لإعادة تعيين المفاتيح لأعداد متتالية:
$collection = collect([
['name' => 'Desk', 'price' => 200],
['name' => 'Chair', 'price' => 100],
['name' => 'Bookcase', 'price' => 150],
]);
$sorted = $collection->sortBy('price');
$sorted->values()->all();
/*
[
['name' => 'Chair', 'price' => 100],
['name' => 'Bookcase', 'price' => 150],
['name' => 'Desk', 'price' => 200],
]
*/
يمكنك تمرير دالة رد النداء الخاصة بك لتحديد طريقة الترتيب:
$collection = collect([
['name' => 'Desk', 'colors' => ['Black', 'Mahogany']],
['name' => 'Chair', 'colors' => ['Black']],
['name' => 'Bookcase', 'colors' => ['Red', 'Beige', 'Brown']],
]);
$sorted = $collection->sortBy(function ($product, $key) {
return count($product['colors']);
});
$sorted->values()->all();
/*
[
['name' => 'Chair', 'colors' => ['Black']],
['name' => 'Desk', 'colors' => ['Black', 'Mahogany']],
['name' => 'Bookcase', 'colors' => ['Red', 'Beige', 'Brown']],
]
*/
()sortByDesc
هذا التابع شبيه بالتابع sortBy
لكنه يرتب العناصر ترتيبًا معاكسًا.
()sortKeys
يرتب التابع المجموعة حسب مفاتيح المصفوفة المعالجة:
$collection = collect([
'id' => 22345,
'first' => 'John',
'last' => 'Doe',
]);
$sorted = $collection->sortKeys();
$sorted->all();
/*
[
'first' => 'John',
'id' => 22345,
'last' => 'Doe',
]
*/
()sortKeysDesc
هذا التابع شبيه بالتابع sortKeys
لكنه يرتّب المجموعة ترتيبًا معاكسًا.
()splice
يحذف التابع ويعيد قطعةً من المجموعة بدءًا من موضع محدّد:
$collection = collect([1, 2, 3, 4, 5]);
$chunk = $collection->splice(2);
$chunk->all();
// [3, 4, 5]
$collection->all();
// [1, 2]
يمكنك تمرير معامل ثاني لتحديد حجم القطعة:
$collection = collect([1, 2, 3, 4, 5]);
$chunk = $collection->splice(2, 1);
$chunk->all();
// [3]
$collection->all();
// [1, 2, 4, 5]
يمكنك أيضًا تمرير معامل ثالث يحتوي عناصر جديدة لتعويض العناصر المحذوفة من المجموعة الأصلية:
$collection = collect([1, 2, 3, 4, 5]);
$chunk = $collection->splice(2, 1, [10, 11]);
$chunk->all();
// [3]
$collection->all();
// [1, 2, 10, 11, 4, 5]
()split
يقسم التابع المجموعة لعدد ممرّر من المجموعات:
$collection = collect([1, 2, 3, 4, 5]);
$groups = $collection->split(3);
$groups->toArray();
// [[1, 2], [3, 4], [5]]
()sum
يعيد التابع مجموع عناصر المجموعة:
collect([1, 2, 3, 4, 5])->sum();
// 15
إذا كانت المجموعة تحتوي مصفوفات متداخلة، يجب تمرير مفتاح لتحديد العناصر التي يجب جمعها:
$collection = collect([
['name' => 'JavaScript: The Good Parts', 'pages' => 176],
['name' => 'JavaScript: The Definitive Guide', 'pages' => 1096],
]);
$collection->sum('pages');
// 1272
يمكنك أيضًا تمرير دالة رد نداء خاصة بك لتحديد أي القيم ستُجمَع:
$collection = collect([
['name' => 'Chair', 'colors' => ['Black']],
['name' => 'Desk', 'colors' => ['Black', 'Mahogany']],
['name' => 'Bookcase', 'colors' => ['Red', 'Beige', 'Brown']],
]);
$collection->sum(function ($product) {
return count($product['colors']);
});
// 6
()take
يعيد التابع مجموعةً جديدةً ذاتُ عناصرٍ محددّة:
$collection = collect([0, 1, 2, 3, 4, 5]);
$chunk = $collection->take(3);
$chunk->all();
// [0, 1, 2]
يمكنك تمرير عدد سالب لأخذ عدد من العناصر من آخر المجموعة:
$collection = collect([0, 1, 2, 3, 4, 5]);
$chunk = $collection->take(-2);
$chunk->all();
// [4, 5]
()tap
يمرّر التابع المجموعة لدالة رد نداء معيّنة. ويسمح لك بالدخول للمجموعة من نقطة محدّدة والقيام بعمل ما على العنصر دون المساس بالمجموعة ككل:
collect([2, 4, 3, 1, 5])
->sort()
->tap(function ($collection) {
Log::debug('Values after sorting', $collection->values()->toArray());
})
->shift();
// 1
()times
يُنشِئ التابع الساكن مجموعة جديدة عبر استعمال دالة رد نداء عددًا محددًا من المرات:
$collection = Collection::times(10, function ($number) {
return $number * 9;
});
$collection->all();
// [9, 18, 27, 36, 45, 54, 63, 72, 81, 90]
يكون هذا التابع مفيدًا عند استعماله مع المصانع لإنشاء نماذج Eloquent:
$categories = Collection::times(3, function ($number) {
return factory(Category::class)->create(['name' => 'Category #'.$number]);
});
$categories->all();
/*
[
['id' => 1, 'name' => 'Category #1'],
['id' => 2, 'name' => 'Category #2'],
['id' => 3, 'name' => 'Category #3'],
]
*/
()toArray
يحوّل التابع المجموعة لمصفوفة PHP. إذا كانت مكوّنات المجموعة نماذج Eloquent، تتحوّل النماذج أيضا لمصفوفات:
$collection = collect(['name' => 'Desk', 'price' => 200]);
$collection->toArray();
/*
[
['name' => 'Desk', 'price' => 200],
]
*/
تنبيه: يحوّل toArray
كل الكائنات المتداخلة في المجموعة لمصفوفات. إذا أردت الحصول على المصفوفة الخام استعمل التابع all
بدلًا منه.
()toJson
يحوّل التابع toJson
المجموعة لسلسلة JSON
:
$collection = collect(['name' => 'Desk', 'price' => 200]);
$collection->toJson();
// '{"name":"Desk", "price":200}'
()transform
يكرّر التابع transform
عناصر المجموعة ويستعمل دالة رد نداء مع كل عنصر. يعوّض العناصر في المجموعة بنتائج النداءات:
$collection = collect([1, 2, 3, 4, 5]);
$collection->transform(function ($item, $key) {
return $item * 2;
});
$collection->all();
// [2, 4, 6, 8, 10]
تنبيه: على عكس أغلب توابع المجموعات، يغيّر التابع المجموعة الأصلية. إذا أردت إنشاء مجموعة جديدة فاستعمل التابع map
بدلًا منه.
()union
يضيف التابع المصفوفة الممرّرة للمجموعة. إذا احتوت المصفوفة مفاتيح موجودة في المجموعة الأصلية، فستُفضَّل قيم المجموعة الأصلية:
$collection = collect([1 => ['a'], 2 => ['b']]);
$union = $collection->union([3 => ['c'], 1 => ['b']]);
$union->all();
// [1 => ['a'], 2 => ['b'], 3 => ['c']]
()unique
يعيد التابع قيمة فريدة في المجموعة. تحتفظ مجموعة النتيجة بالمفاتيح الأصلية لذا في هذا المثال سنستعمل التابع values
لإعادة تعيين المفاتيح لأعداد متتالية:
$collection = collect([1, 1, 2, 2, 3, 4, 2]);
$unique = $collection->unique();
$unique->values()->all();
// [1, 2, 3, 4]
عند العمل مع المصفوفات المتداخلة أو الكائنات، يمكن تحديد المفتاح المستعمل لتحديد الفرادة:
$collection = collect([
['name' => 'iPhone 6', 'brand' => 'Apple', 'type' => 'phone'],
['name' => 'iPhone 5', 'brand' => 'Apple', 'type' => 'phone'],
['name' => 'Apple Watch', 'brand' => 'Apple', 'type' => 'watch'],
['name' => 'Galaxy S6', 'brand' => 'Samsung', 'type' => 'phone'],
['name' => 'Galaxy Gear', 'brand' => 'Samsung', 'type' => 'watch'],
]);
$unique = $collection->unique('brand');
$unique->values()->all();
/*
[
['name' => 'iPhone 6', 'brand' => 'Apple', 'type' => 'phone'],
['name' => 'Galaxy S6', 'brand' => 'Samsung', 'type' => 'phone'],
]
*/
يمكنك أيضا تمرير دالة رد النداء الخاصة بك لتحديد الفرادة:
$unique = $collection->unique(function ($item) {
return $item['brand'].$item['type'];
});
$unique->values()->all();
/*
[
['name' => 'iPhone 6', 'brand' => 'Apple', 'type' => 'phone'],
['name' => 'Apple Watch', 'brand' => 'Apple', 'type' => 'watch'],
['name' => 'Galaxy S6', 'brand' => 'Samsung', 'type' => 'phone'],
['name' => 'Galaxy Gear', 'brand' => 'Samsung', 'type' => 'watch'],
]
*/
يستعمل التابع مقارنة غير صارمة أي أن السلاسل النصية التي تحتوي رقمًا تعدّ مساويةً لعددٍ له القيمة الرقمية. استعمل التابع uniqueStrict
لمقارنةٍ أكثر صرامةً.
()uniqueStrict
هذا التابع شبيه بالتابع unique
لكنه يستعمل مقارنةً صارمةً.
()unless
ينفذ التابع دالة رد النداء الممرَّرة إلا في حالة كان المعامل الأول الممرّر true
:
$collection = collect([1, 2, 3]);
$collection->unless(true, function ($collection) {
return $collection->push(4);
});
$collection->unless(false, function ($collection) {
return $collection->push(5);
});
$collection->all();
// [1, 2, 3, 5]
لعكس وظيفة التابع استعمل التابع when
.
()unwrap
يعيد التابع عناصر المجموعة من القيم الممرّرة عند إمكانية التطبيق:
Collection::unwrap(collect('John Doe'));
// ['John Doe']
Collection::unwrap(['John Doe']);
// ['John Doe']
Collection::unwrap('John Doe');
// 'John Doe'
()values
يعيد التابع مجموعةً جديدةً مع إعادة ضبط المفاتيح لأعداد متتالية:
Collection::unwrap(collect('John Doe'));
// ['John Doe']
Collection::unwrap(['John Doe']);
// ['John Doe']
Collection::unwrap('John Doe');
// 'John Doe'
()when
ينفذّ التابع النداء الممرّر عندما تكون قيمة المعامل الأول true
:
$collection = collect([1, 2, 3]);
$collection->when(true, function ($collection) {
return $collection->push(4);
});
$collection->when(false, function ($collection) {
return $collection->push(5);
});
$collection->all();
// [1, 2, 3, 4]
لعكس وظيفة when
استعمل التابع unless
.
()where
يرشِّح التابع المجموعة عبر الزوج المفتاح/القيمة الممرّر:
$collection = collect([
['product' => 'Desk', 'price' => 200],
['product' => 'Chair', 'price' => 100],
['product' => 'Bookcase', 'price' => 150],
['product' => 'Door', 'price' => 100],
]);
$filtered = $collection->where('price', 100);
$filtered->all();
/*
[
['product' => 'Chair', 'price' => 100],
['product' => 'Door', 'price' => 100],
]
*/
يستعمل التابع مقارنة غير صارمة أي أن السلاسل النصية التي تحتوي رقمًا تعدّ مساويةً لعدد بنفس القيمة الرقمية. استعمل التابع whereStrict
لمقارنةٍ أكثر صرامةً.
()whereStrict
يشبه هذا التابع عمل where
لكنه يستعمل مقارنةً صارمةً.
()whereIn
يرشِّح التابع المجموعة عبر الزوج المفتاح\القيمة المحتواة في المصفوفة الممرّرة:
$collection = collect([
['product' => 'Desk', 'price' => 200],
['product' => 'Chair', 'price' => 100],
['product' => 'Bookcase', 'price' => 150],
['product' => 'Door', 'price' => 100],
]);
$filtered = $collection->whereIn('price', [150, 200]);
$filtered->all();
/*
[
['product' => 'Bookcase', 'price' => 150],
['product' => 'Desk', 'price' => 200],
]
*/
يستعمل التابع مقارنة غير صارمة أي أن السلاسل النصية التي تحتوي رقمًا تعدّ مساويةً لعددٍ بنفس القيمة الرقمية. استعمل التابع whereInStrict
لمقارنةٍ أكثر صرامةً.
()whereInStrict
يشبه هذا التابع عمل whereIn
لكنه يستعمل مقارنةً صارمة.
()whereInstanceOf
يرشِّح التابع المجموعة حسب صنف ممرّر:
$collection = collect([
new User,
new User,
new Post,
]);
return $collection->whereInstanceOf(User::class);
()whereNotIn
يرشِّح التابع المجموعة حسب زوج المفتاح/القيمة غير مجموعة في المصفوفة الممرّرة:
$collection = collect([
['product' => 'Desk', 'price' => 200],
['product' => 'Chair', 'price' => 100],
['product' => 'Bookcase', 'price' => 150],
['product' => 'Door', 'price' => 100],
]);
$filtered = $collection->whereNotIn('price', [150, 200]);
$filtered->all();
/*
[
['product' => 'Chair', 'price' => 100],
['product' => 'Door', 'price' => 100],
]
*/
يستعمل التابع مقارنة غير صارمة أي أن السلاسل النصية التي تحتوي رقمًا تعدّ مساويةً لعددٍ بنفس القيمة الرقمية. استعمل التابع whereNotInStrict
لمقارنةٍ أكثر صرامة.
()whereNotInStrict
يشبه هذا التابع عمل whereNotIn
لكنه يستعمل مقارنةً صارمةً.
()wrap
يغلِّف التابع الثابت القيمة في مجموعة عند تطبيقه:
$collection = Collection::wrap('John Doe');
$collection->all();
// ['John Doe']
$collection = Collection::wrap(['John Doe']);
$collection->all();
// ['John Doe']
$collection = Collection::wrap(collect('John Doe'));
$collection->all();
// ['John Doe']
()zip
يدمج التابع zip
قيم المصفوفات الممرّرة في المواضع المناسبة:
$collection = collect(['Chair', 'Desk']);
$zipped = $collection->zip([100, 200]);
$zipped->all();
// [['Chair', 100], ['Desk', 200]]
الرسائل ذات الترتيب العالي
توفّر المجموعات دعمًا للرسائل ذات الترتيب العالي (higher order messages)، وهي طرق مختصرة لتنفيذ أعمال شائعة على المجموعات. التوابع التي توفر رسائل ذات ترتيب عالي هي: average
و avg
و contains
و each
و every
و filter
و first
و flatMap
و groupBy
و keyBy
و map
و max
و min
و partition
و reject
و sortBy
و sortByDesc
و sum
و unique
.
يمكن الوصول لكل رسالة ذات ترتيب عالي كخاصية ديناميكية لكائن المجموعة. مثلًا، لنستعمل رسائل التابع each
لنداء تابع مع كل عنصر في المجموعة:
$users = User::where('votes', '>', 500)->get();
$users->each->markAsVip();
بنفس الطريقة، يمكن استعمال رسائل sum
لجمع أصوات (votes) مجموعة مستخدمين:
$users = User::where('group', 'Development')->get();
return $users->sum->votes;