簡體   English   中英

Twig模板訪問Symfony 3.4中的舊變量值

[英]Twig template access old variable value in 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”和“”。

我做錯了什么與表格有關?

預先感謝您的任何建議。

更新

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

這可能會有所幫助。 背景:該網站的首頁顯示了一個由highcharts創建的圖表,該圖表是javascript圖表生成器。 因為圖表需要數據庫中的值,所以我需要創建一個Twig模板以用作javascript。

關鍵:一個包含JavaScript的...js.twig文件,一個用於渲染(而非renderView)模板的控制器動作以及一個需要插入腳本的頁面中的render(controller(...)) 。劇本。

所以我有:

script.js.twig

$(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.twig中”

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

並在../Controller/Default/script中

public function scriptAction(FYChart $fiscalYearChart)
{
    $chart = $fiscalYearChart->getDistsFYToDate();

    return $this->render('Default/script.js.twig', array(
                'chart' => $chart,
    ));
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM