承接 quellabs/canvas-handlebars 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

quellabs/canvas-handlebars

最新稳定版本:1.0.2

Composer 安装命令:

composer require quellabs/canvas-handlebars

包简介

Handlebars template engine integration for the Canvas PHP framework via LightnCandy, with contextual containers and automatic service discovery

README 文档

README

A Handlebars template engine integration for the Canvas PHP framework, powered by LightnCandy.

Installation

composer require quellabs/canvas-handlebars

Requirements

  • PHP 8.3 or higher
  • Canvas framework

How it works

Unlike output-cache engines (Smarty, Twig), LightnCandy compiles Handlebars templates to native PHP closures. The compiled files are stored in compile_dir and reused across requests. Recompilation only happens when a source template is newer than its compiled counterpart — no opcode cache invalidation overhead.

Usage

The Handlebars template engine is automatically registered with Canvas through the service discovery system.

class HomeController {
    public function index(TemplateEngineInterface $handlebars) {
        return $handlebars->render('home.hbs', [
            'title' => 'Welcome to Canvas',
            'user'  => $user
        ]);
    }
}

Template Files

templates/
├── home.hbs
├── layouts/
│   └── app.hbs
└── partials/
    └── header.hbs

Helpers

Register helpers in config/handlebars.php:

'helpers' => [
    'uppercase'  => fn($str)  => strtoupper($str),
    'formatDate' => fn($ts)   => date('Y-m-d', $ts),
],

Or register them at runtime via the engine instance:

$handlebars->registerHelper('uppercase', fn($str) => strtoupper($str));

Use in templates:

<h1>{{uppercase title}}</h1>
<p>Published: {{formatDate createdAt}}</p>

Partials

Partials are reusable template fragments. Register them as strings in config or at runtime:

$handlebars->registerPartial('header', '<header>{{siteName}}</header>');

Use in templates:

{{> header}}
<main>{{content}}</main>

Configuration

Key Default Description
template_dir templates/ Where .hbs files are stored
compile_dir storage/handlebars/compile/ Where compiled PHP renderers are cached
strict_mode false Throw on missing variables instead of rendering empty
standalone false Embed helpers in compiled output (no runtime dependency)
helpers [] Named helper callables
partials [] Named partial template strings
globals [] Variables available in all templates

Sculpt Commands

php sculpt handlebars:clear-cache

Removes all compiled PHP renderers, forcing recompilation on the next request.

License

MIT License

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 5
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-03-26

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固