0

0

如何在前端按分类动态展示指定数量的图片(如每类10张)

心靈之曲

心靈之曲

发布时间:2026-02-03 10:29:08

|

551人浏览过

|

来源于php中文网

原创

如何在前端按分类动态展示指定数量的图片(如每类10张)

本文详解如何在 laravel 项目中正确实现“按分类(如 fabrikasi、konstruksi 等)分别获取并展示最多 10 张作品图”,解决因错误使用 `take(10)` 或循环逻辑缺陷导致的图片不显示问题。

在构建企业官网或作品集页面时,常需将作品(Portfolio)按业务类别(如“Fabrikasi”“Konstruksi”“Repair”“Lainnya”)分组展示,并严格限制每类仅显示最新 10 张图。你当前遇到的问题——take(10) 在控制器中看似生效,但在 Blade 中仍无法正确渲染对应分类的图片(例如新增第 11 张 fabrikasi 图后,该分类反而只显示 3 张),根本原因在于:你在 Blade 中仍遍历了全部 $portfolios,却用 $loop->iteration 错误地判断全局序号,而非当前分类内的序号——这会导致“只要总序号超过 10,后续所有分类图片均被跳过”。

✅ 正确做法是:控制器按分类预查询、预截取;Blade 中直接遍历对应分类集合

✅ 控制器优化(推荐简洁写法)

避免重复书写多个 where()->latest()->take(10)->get(),可统一处理:

// app/Http/Controllers/LandingController.php
public function landing()
{
    $numbers = Number::get();
    $testimonials = Testimonial::get();
    $clients = Client::get();

    // 定义分类映射(数据库中 category 字段值 → 前端 class 过滤器名)
    $categories = [
        'fabrikasi'   => 'filter-fabrication',
        'konstruksi'  => 'filter-construction',
        'repair'      => 'filter-repairs',
        'lainnya'     => 'filter-design',
    ];

    // 预加载各分类的前 10 条最新作品
    $portfoliosByCategory = [];
    foreach ($categories as $dbValue => $filterClass) {
        $portfoliosByCategory[$dbValue] = Portfolio::where('category', $dbValue)
            ->latest('created_at') // 明确按 created_at 排序(避免无索引字段歧义)
            ->take(10)
            ->get();
    }

    return view('landing/landing', compact(
        'numbers', 'testimonials', 'clients',
        'portfoliosByCategory'
    ));
}

✅ Blade 模板正确渲染方式

不再遍历 $portfolios 全集,而是分别渲染每个预处理好的分类集合:

立即学习前端免费学习笔记(深入)”;


  • All
  • Fabrikasi
  • Konstruksi
  • Repair
  • Lainnya
@foreach($portfoliosByCategory['fabrikasi'] as $portfolio)
@@##@@image) }}" class="img-fluid" alt="{{ $portfolio->title }}">

{{ $portfolio->title }}

{{ $portfolio->category }}

Shop7z网上购物系统时尚版
Shop7z网上购物系统时尚版

Shop7z商城系统时尚版支持支付宝、微信支付等多种常用接口,电脑版与手机版与APP无缝结合数据一体!支持图片批量上传,一次性可上传任意张图片,支持多种在线支付接口,如支付宝、网银在线、财付通等接口,支持多级商品分类划分功能,可以方便的划分各商品类别的上下级关系,支持新订单邮件自动通知功能,支持单商品多分类展示功能,订单方面设计完美,如支持订单模糊查询、订单状态的编辑及打印等功能,灵活的导航可以设

下载
View
@endforeach @foreach($portfoliosByCategory['konstruksi'] as $portfolio)
@@##@@image) }}" class="img-fluid" alt="{{ $portfolio->title }}">

{{ $portfolio->title }}

{{ $portfolio->category }}

View
@endforeach @foreach($portfoliosByCategory['repair'] as $portfolio)
@@##@@image) }}" class="img-fluid" alt="{{ $portfolio->title }}">

{{ $portfolio->title }}

{{ $portfolio->category }}

View
@endforeach @foreach($portfoliosByCategory['lainnya'] as $portfolio)
@@##@@image) }}" class="img-fluid" alt="{{ $portfolio->title }}">

{{ $portfolio->title }}

{{ $portfolio->category }}

View
@endforeach

⚠️ 关键注意事项

  • 路径安全:确保 $portfolio->image 存储的是相对路径(如 uploads/portfolio/abc.jpg),并在 Blade 中用 asset() 生成完整 URL;若为绝对 URL,请直接输出。
  • 排序可靠性:->latest() 默认按 updated_at 排序,建议显式使用 ->latest('created_at') 并确保该字段有数据库索引。
  • 空分类容错:可在 @foreach 外加 @if($portfoliosByCategory['fabrikasi']->count()) 判断是否为空,提升健壮性。
  • 性能优化:如分类较多或数据量大,可考虑使用 Eloquent 的 when() + 单次查询 + PHP 分组,但当前 4 类 × 10 条完全适用预查询方案。

通过以上重构,每类作品严格展示最新 10 条,且新增作品后自动更新展示内容,彻底规避因循环逻辑错误引发的“图片消失”问题。

如何在前端按分类动态展示指定数量的图片(如每类10张)如何在前端按分类动态展示指定数量的图片(如每类10张)

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

321

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

281

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

435

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

374

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

86

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

72

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

68

2025.08.05

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

788

2023.08.22

Python 序列化
Python 序列化

本专题整合了python序列化、反序列化相关内容,阅读专题下面的文章了解更多详细内容。

12

2026.02.02

热门下载

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

精品课程

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

共137课时 | 10.9万人学习

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号