Шаблон 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
        ));

Странно то, что контроллер улавливает изменение значений двух переменных, тогда как шаблон веточки всегда печатает «S» и «» для $selected_tipoopera и $selected_year.

Что я делаю не так? Это что-то связано с формой?

заранее спасибо за любое предложение.

ОБНОВИТЬ

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

Не могли бы вы показать нам код шаблона Twig, в котором отображаются эти переменные?

yceruto 14.11.2018 18:25

@yceruto сообщение обновлено кодом веточки

SimoBrazz 15.11.2018 09:03

@yceruto Я нашел обходной путь! Я не могу распечатать переменные в javascript, но в html. Поэтому я могу получить доступ к элементу html с помощью javascript (например, jQuery), чтобы получить их значение. Однако я думаю, что это должно быть возможно использовать Twig с переменными Symfony с некоторым типом escape (но я не могу найти правильный путь!).

SimoBrazz 15.11.2018 15:10
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
1
3
249
1

Ответы 1

Вот кое-что, что может помочь. Фон: на главной странице сайта показана диаграмма, созданная с помощью высокие диаграммы, генератора диаграмм на языке javascript. Поскольку диаграмме нужны значения из базы данных, мне нужно было создать шаблон Twig, который можно было бы использовать как javascript.

Ключи: файл ...js.twig, содержащий javascript, действие контроллера для рендеринга (не 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,
    ));
}

Другие вопросы по теме