0

0

Laravel中如何使用集合Collection_Laravel集合常用函数用法介绍【汇总】

尼克

尼克

发布时间:2026-01-26 14:59:03

|

132人浏览过

|

来源于php中文网

原创

Collection是Laravel具备链式调用、惰性求值与不可变语义的核心对象,非数组封装;应使用first()/last()而非下标访问,filter/where/reject各司其职,map()返回新实例而transform()修改原集合,chunk/splice/partition适用不同切片场景。

laravel中如何使用集合collection_laravel集合常用函数用法介绍【汇总】

Collection 是 Laravel 的核心工具,不是语法糖,别当数组用

Collection 不是 PHP 数组的简单封装,而是一个具备链式调用、惰性求值(部分方法)、不可变语义(多数方法返回新实例)的对象。直接用 foreach 遍历或用 [] 下标访问虽能工作,但会丢失过滤、映射、分页等关键能力,也容易在嵌套操作中引发意外的引用问题。

常见错误现象:
– 用 $collection[0] 取首项,结果报错(Collection 不支持数组下标访问)
– 链式调用中途赋值给变量,后续修改原变量却误以为影响了前面的链路(实际每步都返回新实例)
– 在循环中反复调用 push() 构建集合,性能差且违背函数式习惯

  • 取首项用 first(),末项用 last(),不支持 $col[0]
  • 需要“就地修改”时,明确用 transform()mapInto() 等可变方法(少数)
  • 构建集合优先用 collect($array) 一次性初始化,避免循环中 push()

filter() / where() / reject() 这三个最常混用的方法怎么选

filter()回调函数,做任意逻辑判断;where() 是快捷键,只适合简单字段匹配(支持点号路径、== 语义、支持 null 安全比较);reject()filter() 的反向——别用 filter(fn => !condition) 替代 reject(),语义不清且少一层优化。

collect([
    ['name' => 'Alice', 'active' => true, 'score' => 85],
    ['name' => 'Bob',   'active' => false, 'score' => 92],
    ['name' => 'Cara',  'active' => true,  'score' => null],
])
->where('active', true)           // ✅ 简单布尔匹配
->where('score', '>=', 90)        // ✅ 支持操作符
->where('name.0', 'A')            // ✅ 支持点号取嵌套字符串首字符
->reject(fn ($u) => $u['score'] === null); // ✅ 明确排除空分

注意:where('score', null) 会同时匹配 null0(松散比较),要严格判空请用 whereNull('score')reject() + 闭包。

NeoAgent
NeoAgent

销售易推出的AI‑CRM智能体平台

下载

map() vs transform():什么时候该改原集合,什么时候该生成新集合

map() 返回全新 Collection,原集合不变;transform() 直接修改当前实例(返回 $this),适用于需复用同一变量名、且后续不再需要原始数据的场景。Laravel 官方文档强调“Collection 默认不可变”,所以 transform() 是显式打破约定的操作,应有明确理由。

  • 处理响应数据、构造 API 输出:用 map() —— 保持输入干净,便于调试和复用
  • 批量更新模型属性后立即用于保存:可用 transform(),避免多一次实例化开销
  • map() 内部不支持修改原数组键名;如需重键,用 mapWithKeys()
  • transform() 对空集合无效(不报错但无效果),而 map() 总是返回新实例

chunk() / splice() / partition() 这些“切片类”方法的真实适用边界

它们解决的是不同维度的拆分需求:chunk() 按数量均分(适合分批处理队列任务);splice() 类似数组的 array_splice(),支持删除+插入+偏移(适合 UI 层动态插入广告位);partition() 是二元分类(如把用户分成“已验证”和“未验证”两组),返回含两个子集的数组,不是 Collection。

$users = collect([/* ... */]);
// 分批发邮件,每 50 人一批
$users->chunk(50)->each(function ($batch) {
    Mail::to($batch)->send(new WelcomeBatch());
});

// 在第 3 个位置插入一个推荐用户 $users->splice(3, 0, [new User(['name' => 'Sponsored'])]);

// 一分为二,得到 [verified, unverified] [$verified, $unverified] = $users->partition('email_verified_at'); // 注意:返回的是 array,不是 Collection

容易被忽略的点:partition() 返回的是 PHP 数组,不是 Collection 实例,如果后续还要链式操作,得再包一层 collect()splice() 的第二个参数是“删除数量”,传 0 才是纯插入,这点和 JS 的 splice() 一致,但常被 PHP 开发者误写成 1

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2899

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1734

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1567

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

1120

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1546

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1277

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1669

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1310

2023.11.13

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

31

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 9.5万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号