Twig模板访问Symfony 3.4中的旧变量值



我正在处理Symfony 3.4中与Twig相关的问题。基本上,我有两个变量,我想将它们用作模板中javascript的值。这两个变量($selected_tipoopera$selected_year(可以通过由呈现模板的同一控制器管理的表单进行更改。

控制器的代码如下:

    $selected_tipo_opera = "S"; // the default value
    $selected_year = ""; // the default value
    // other stuff / code (form creation and management of form events)
    $form_operas_type_and_year->handleRequest($request);
    if($form_operas_type_and_year->isSubmitted() && $form_operas_type_and_year->isValid()){
        $selected_tipo_opera = $form_operas_type_and_year->getData()["operas_type"];
        $selected_year = $form_operas_type_and_year->getData()["year"];
    }

    // fetch data based on $selected_tipo_opera and $selected_year
    return $this->render('frontend/opere.html.twig', 
        array(
            "opere" => $opere,
            "form_operas_type_and_year" => $form_operas_type_and_year->createView(),
            "selected_tipoopera" => $selected_tipo_opera,
            "selected_year" => $selected_year
        ));

奇怪的是,控制器捕捉到两个变量的值的变化,而分支模板总是为$selected_tipoopera$selected_year打印"S"one_answers"。

我做错了什么?这是与形式有关的东西吗?

提前谢谢你的任何建议。

更新

<script type="text/javascript">
    var year = "{{ selected_year }}";
    var stp = "{{ selected_tipoopera }}";
</script>

以下内容可能会有所帮助。背景:该网站的主页显示了一个用highcharts创建的图表,这是一个javascript图表生成器。因为图表需要数据库中的值,所以我需要创建一个可以用作javascript的Twig模板。

关键点:一个包含javascript的...js.twig文件,一个用于渲染(而非renderView(模板的控制器操作,以及一个需要脚本插入脚本的页面中的render(controller(...))

所以我有:

script.js.titch

$(document).ready(function () {
    var options = {
        chart: {
            type: 'line'
        },
        title: {
            text: 'Distributions, FY{{ chart.fy }} to date'
        },
        xAxis: {
            categories: [{% for category in chart.categories %}{{category|raw}}{%endfor%}]
        },
        yAxis: {
            title: {
                text: 'Distributions'
            }
        },
        series: {{ chart.series|raw }}
    };
    $('#linechart').highcharts(options);
})

在index.html.titch">

<script type="text/javascript">
    {{ render(controller('AppBundle:Default:script')) }}
</script>

并且在/控制器/默认值/脚本

public function scriptAction(FYChart $fiscalYearChart)
{
    $chart = $fiscalYearChart->getDistsFYToDate();
    return $this->render('Default/script.js.twig', array(
                'chart' => $chart,
    ));
}

最新更新