您的位置:首页 >PHP Handlebars 无哈希助手实现方法
发布于2025-09-28 阅读(0)
扫一扫,手机访问

PHP Handlebars (salesforce/handlebars) 是一个用于解析和渲染 JavaScript Handlebars 模板的 PHP 库。虽然 JavaScript Handlebars 提供了块助手和非块助手两种类型的助手,但 PHP Handlebars 似乎原生不支持与 JavaScript Handlebars 语法完全一致的非块助手。本文将介绍一种修改 PHP Handlebars 核心文件的方法,以实现类似非块助手的功能。
在 JavaScript Handlebars 中,非块助手可以直接在模板中使用,例如 {{helperName argument1 argument2}}。这种助手通常用于生成简单的 HTML 属性或文本片段。然而,在 PHP Handlebars 中,直接注册和使用这种类型的助手可能会遇到问题,特别是当需要在 PHP 和 JavaScript 环境中共享模板时。
由于 PHP Handlebars 默认不支持非块助手,我们需要修改其核心文件 Handlebars/Template.php,在 variables 函数中添加自定义逻辑来处理这类助手。
具体步骤如下:
定位 variables 函数: 打开 Handlebars/Template.php 文件,找到 private function variables(Context $context, $current, $escaped) 函数。
添加自定义助手逻辑: 在该函数中,添加以下代码块,用于检测和处理非块助手:
/* LS20211101 */
/* Check for non-block helpers {{{ */
// "Arguments" are subjected to a VERY simple parsing, with NO
// syntax check. Just simple variables (plus @index and @key)
// and strings between double quotes, parsed through
// dirty base64 glomping.
$words = preg_split('#\\s+#', $name, 2, PREG_SPLIT_NO_EMPTY);
$code = $words[0];
if ($this->handlebars->hasHelper($code)) {
$return = call_user_func_array(
$this->handlebars->getHelper($words[0]),
[
$this, // First argument is this template
$context, // Second is current context
implode(
' ',
array_map(
function ($token) use ($context) {
if ('"' === substr($token, 0, 1)) {
return base64_decode($token);
}
// If @data variables are not enabled, then revert back to legacy behavior
if ($token == '@index') {
return $context->lastIndex();
}
if ($token == '@key') {
return $context->lastKey();
}
return $context->get($token);
},
preg_split(
'#\\s+#',
preg_replace_callback(
'#"([^"]*)"#',
function ($matches) {
return '"' . base64_encode($matches[1]) . '"';
},
$words[1]
),
-1,
PREG_SPLIT_NO_EMPTY
)
)
), // Arguments
''
]);
if ($return instanceof String) {
return $this->handlebars->loadString($return)->render($context);
}
return $return;
}
/** }}} end */代码解释:
假设我们需要创建一个名为 checked 的非块助手,用于在复选框中添加 checked 属性。
$handlebars = new HandlebarsEngine();
$handlebars->addHelper('checked', function ($template, $context, $value) {
if ($value) {
return 'checked="checked"';
}
return '';
});<input name="acheckbox" {{checked record.acheckbox}} /><input name="acheckbox" checked="checked" />
否则,渲染结果为:
<input name="acheckbox" />
虽然 PHP Handlebars 官方库没有直接提供与 JavaScript Handlebars 完全一致的非块助手,但通过修改 Handlebars/Template.php 文件,我们可以实现类似的功能。这种方法允许我们在 PHP Handlebars 模板中使用自定义的非块助手,从而提高模板的灵活性和可重用性。然而,需要注意的是,修改核心文件可能会导致兼容性问题,并且需要谨慎处理参数解析和安全性问题。在实际应用中,请根据具体需求权衡利弊,选择最合适的解决方案。
下一篇:360浏览器关闭夜间模式教程
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9