信息列表 - 布局
Section
概述
你可以将多个 Entry 分到不同的分区(Section)中,每个都有一个标题及描述。为此,你可以使用 Section 组件:
use Filament\Infolists\Components\Section; Section::make('Rate limiting') ->description('Prevent abuse by limiting the number of requests per period') ->schema([ // ... ])
data:image/s3,"s3://crabby-images/56dd5/56dd5ed44a234c3a3c0738e1c3856f9f5704220f" alt="Section"
你也可以使用不带头部的分区,只需这样包裹子组件:
use Filament\Infolists\Components\Section; Section::make() ->schema([ // ... ])
data:image/s3,"s3://crabby-images/08633/0863338df4150c3a979f51537fb982dbf07b82cd" alt="Section without header"
添加 Action 到 Section 头部或者尾部
Section 可以在其头部或者尾部(#添加-action-到-section-尾部)添加 Action。
添加 Action 到 Section 头部
使用 headerActions()
方法,你可以将 Action 添加到 Section 头部:
use Filament\Infolists\Components\Actions\Action;use Filament\Infolists\Components\Section; Section::make('Rate limiting') ->headerActions([ Action::make('edit') ->action(function () { // ... }), ]) ->schema([ // ... ])
data:image/s3,"s3://crabby-images/3e145/3e145a03db97b8904bbbcfd83a9d5a6c8324c69d" alt="Section with header actions"
添加 Action 到 Section 尾部
除了 Header Action,你也可以使用 footerActions()
方法,你可以将 Action 添加到 Section 尾部:
use Filament\Infolists\Components\Actions\Action;use Filament\Infolists\Components\Section; Section::make('Rate limiting') ->footerActions([ Action::make('edit') ->action(function () { // ... }), ]) ->schema([ // ... ])
data:image/s3,"s3://crabby-images/a093b/a093b704e83e6882a1382d0ee0ae4ae42d07f680" alt="Section with footer actions"
对齐 Section 尾部 Action
尾部(Footer) Action 会默认对齐到行内起始位置。你可以使用 footerActionsAlignment()
方法来自定义对齐方式:
use Filament\Infolists\Components\Actions\Action;use Filament\Infolists\Components\Section;use Filament\Support\Enums\Alignment; Section::make('Rate limiting') ->footerActions([ Action::make('edit') ->action(function () { // ... }), ]) ->footerActionsAlignment(Alignment::End) ->schema([ // ... ])
不带标题添加 Action
如果 Section 没有标题,Filament 无法在其内部定位 Action。这种情况下,你必须传入一个唯一的 id()
到该 Section 中:
use Filament\Infolists\Components\Section; Section::make() ->id('rateLimitingSection') ->headerActions([ // ... ]) ->schema([ // ... ])
添加图标到 Section 头部
使用 icon()
方法,你可以将图标添加到 Section 头部:
use Filament\Infolists\Components\Section; Section::make('Cart') ->description('The items you have selected for purchase') ->icon('heroicon-m-shopping-bag') ->schema([ // ... ])
data:image/s3,"s3://crabby-images/d2eb1/d2eb1d303ca3c2380a672b90e2ffedadc91f6990" alt="Section with icon"
将标题和描述放在边上
你可以使用 aside()
方法将左侧的标题和描述,与卡片内右侧的消息列表组件对齐。
use Filament\Infolists\Components\Section; Section::make('Rate limiting') ->description('Prevent abuse by limiting the number of requests per period') ->aside() ->schema([ // ... ])
data:image/s3,"s3://crabby-images/31c6f/31c6fff221bd13637dee2adf066840ed24da5b1d" alt="Section with heading and description aside"
折叠 Section
Section 可设为可折叠 collapsible()
,以选择性隐藏长信息列表中的内容:
use Filament\Infolists\Components\Section; Section::make('Cart') ->description('The items you have selected for purchase') ->schema([ // ... ]) ->collapsible()
你可以将分区设为默认折叠,请使用 collapsed()
:
use Filament\Infolists\Components\Section; Section::make('Cart') ->description('The items you have selected for purchase') ->schema([ // ... ]) ->collapsed()
data:image/s3,"s3://crabby-images/4c4c5/4c4c5d006366606dfe409d858f35d3a4143cfd1c" alt="Collapsed section"
持久化折叠 Section
使用 persistCollapsed()
方法,你可以在本地存储中对一个 Section 是否折叠进行持久化,使之在用户刷新页面后保持折叠:
use Filament\Infolists\Components\Section; Section::make('Cart') ->description('The items you have selected for purchase') ->schema([ // ... ]) ->collapsible() ->persistCollapsed()
要持久化折叠状态,本地存储需要一个唯一 ID 来储存状态。该 ID 基于 Section 的标题生成。如果该 Section 没有标题,或者你有多个想要折叠的 Section 使用了同一个标题,你可以手动指定 id()
以防止 ID 冲突:
use Filament\Infolists\Components\Section; Section::make('Cart') ->description('The items you have selected for purchase') ->schema([ // ... ]) ->collapsible() ->persistCollapsed() ->id('order-cart')
压缩 Section 样式
当嵌套 Section 时,你可以使用更加紧凑的样式:
use Filament\Infolists\Components\Section; Section::make('Rate limiting') ->description('Prevent abuse by limiting the number of requests per period') ->schema([ // ... ]) ->compact()
data:image/s3,"s3://crabby-images/e8c0d/e8c0de44a7f7e84e36b9df0c2ad7c4d3c2cd84af" alt="Compact section"
在分区中使用网格 columns
你也可以使用 columns()
方法,在分区内轻松创建 Grid:
use Filament\Infolists\Components\Section; Section::make('Heading') ->schema([ // ... ]) ->columns(2)
Edit on GitHubStill need help? Join our Discord community or open a GitHub discussion