响应式 Twig 模板
一个互动式 UI
在 PHP 和 Twig 中
在舒适的 Symfony 环境中开发你的界面。
无需 Javascript。
composer require symfony/ux-live-component
// ... use statements hidden - click to show
#[AsLiveComponent('SearchPackages', template: 'components/Package/SearchPackages.html.twig')]
class SearchPackages
{
use DefaultActionTrait;
#[LiveProp(writable: true, url: true)]
public ?string $query = null;
public function __construct(private UxPackageRepository $packageRepo)
{
}
public function getPackages(): array
{
return $this->packageRepo->findAll($this->query);
}
}
<div{{ attributes }}>
<input type="text" data-model="query" placeholder="Results update as you type..." class="form-control" />
<div class="PackageList pt-3" data-loading="addClass(opacity-50)">
{% for package in computed.packages %}
{{ include('components/Package/PackageListItem.html.twig', {package}) }}
{% else %}
No packages found "{{ query }}"
{% endfor %}
</div>
</div>
data:image/s3,"s3://crabby-images/6c7bf/6c7bf2a4b854b687aab5cfd65b01751da155d718" alt="Symfony logo"
Live Components
安装它
$ composer require symfony/ux-live-component
Live Component 演示
了解您还可以构建什么
阅读完整文档data:image/s3,"s3://crabby-images/b1569/b1569191aad865d51a5654091dd8e7787ff1f253" alt="Infinite Scroll - 2/2 demo preview"
无限滚动 - 2/2
滚动加载、灵活的布局网格、多彩的加载动画以及... 更多 T 恤衫!
data:image/s3,"s3://crabby-images/6008a/6008a44c45e20d39703ec4f8f3071116add69b22" alt="Infinite Scroll - 1/2 demo preview"
无限滚动 - 1/2
当您向下滚动页面时加载更多项目。
data:image/s3,"s3://crabby-images/6dbf6/6dbf6028c7621f2cf9a05c6156bccf09c3ab9cd2" alt="Live Memory Card Game demo preview"
Live Memory Card Game
使用 Live Components 打造令人难忘的游戏 UX!
data:image/s3,"s3://crabby-images/38ddd/38ddd6847542143bf2c0c8dfc902589ac6818a28" alt="Auto-Validating Form demo preview"
自动验证表单
创建一个表单,当用户输入数据时,实时验证每个字段!
data:image/s3,"s3://crabby-images/fcb88/fcb883c6999e58aad3fbe2a02087041ff9ce8d3f" alt="Embedded CollectionType Form demo preview"
嵌入式 CollectionType 表单
在 Twig 中创建带有功能性“添加”和“删除”按钮的嵌入式表单。
data:image/s3,"s3://crabby-images/742d4/742d49c3710520f31e69b26c77ca60a9c2ce7ae1" alt="Dependent Form Fields demo preview"
依赖表单字段
选择第一个字段后,自动重新加载第二个字段的选项。
data:image/s3,"s3://crabby-images/28ce7/28ce7afb71dd933f3a923a1a9b6a5075b088e58d" alt="Up & Down Voting demo preview"
赞成和反对投票
在纯 Twig 和 PHP 中实时保存赞成和反对票。
data:image/s3,"s3://crabby-images/17572/17572029e3b7662324063b7055e897517dc3c7d2" alt="Inline Editing demo preview"
在线编辑
激活具有实时验证的在线编辑表单。
data:image/s3,"s3://crabby-images/77851/77851eec6670e7329fb5d04ce70a9159226b6f36" alt="Auto-Updating Chart demo preview"
自动更新图表
实时渲染和更新 Chart.js 图表。
data:image/s3,"s3://crabby-images/9ed07/9ed07b8ad0f0cdc68a3e6431498c8547f1d0b3c6" alt="Invoice Creator demo preview"
发票创建器
创建一个发票 + 行项目,并在您键入时更新。
data:image/s3,"s3://crabby-images/531dd/531dd9bdbe768c2626c51453ca5a5fdb037dd589" alt="Product Form + Category Modal demo preview"
产品表单 + 类别模态框
在产品表单内 - 通过模态框 - 动态创建类别。
data:image/s3,"s3://crabby-images/4f9f9/4f9f98170e0722a713679e76dd275746768083dc" alt="Uploading files demo preview"
上传文件
通过 LiveAction 从您的 live component 上传文件。