2

次のようなテンプレートのマクロを作成しようとしています:

{%- macro bField(form, name, attributes) %}
    <p class="form-group" ng-class="{has-error: !{{ form.name }}.{{ name }}.$valid}">
        {{ form.label(name) }}
        {#{% set attributes['class'] = 'form-control' %}#}
        {{ form.render(name, attributes) }}
        {% include 'forms/validation-messages.volt' %}
    </p>
{%- endmacro %}

問題は、それがビューのルートにある macros.volt ファイルにあり、それをどこにどのように含めるかがわからないため、どこでも利用できることです。インクルード関数と部分関数を使用してルート レイアウト (index.volt) を試しましたが、まだ機能しません。テンプレートファイルでさえ、私はそれを使用しようとしています.私は何を間違っていますか?これを修正するにはどうすればよいですか?

もう 1 つのことは、配列内の特定のキーに値を設定する方法です。私は明らかに試し{% set attributes['class'] = 'form-control' %}ましたが、うまくいきません。

4

1 に答える 1

6

Phalcon Forumsにある素晴らしいソリューション。私の状況に合わせて少しだけカスタマイズしました。

Volt エンジン クラスを拡張し、実行中に各マクロ ファイルをロードすることをお勧めします\Phalcon\Mvc\View\Engine\Volt::getCompiler

// extended class to load the macros before parse time
class VoltC extends \Phalcon\Mvc\View\Engine\Volt
{
    public function getCompiler()
    {
      if (empty($this->_compiler))
      {
        parent::getCompiler();

        // add macros that need initialized before parse time
        $this->partial("macros/form");
      }

      return parent::getCompiler();
    }
}
$di->set("voltEngine", function( $view, $di ){
    $volt = new VoltC($view, $di);

    $volt->setOptions(array(
        "compiledPath" => "../app/tmp/cache/",
        "compiledExtension" => ".cmp",
        'compileAlways' => true
    ));

    return $volt;
});
于 2013-11-02T19:18:44.263 に答える