【问题标题】:Twig and javascript树枝和 JavaScript
【发布时间】:2012-10-09 10:31:28
【问题描述】:

我正在创建一个页面,该页面根据组合框中选择的类型显示图表

<div id="chartdiv"></div>

<select name="graphe" id="identifiantDeMonSelect">
<option value="Column2D">Column2D
<option value="Column3D">Column3D
<option value="Pie3D">Pie3D
<option value="Pie2D">Pie2D
</select>
<input type="submit" value="Afficher" onclick="ajax()">


<script type="text/javascript">
function ajax(){
    var xhr

    if (window.XMLHttpRequest) { 
        xhr = new XMLHttpRequest();
    }
    else if (window.ActiveXObject) 
    {
        xhr = new ActiveXObject("Microsoft.XMLHTTP");
    }

    if (xhr !=null)  {
    xhr.onreadystatechange = function() { type1(xhr); };
    xhr.open("GET", "{{ path('Ajax')}}", true);
    xhr.send(null);
    } else {

     alert("The XMLHttpRequest not supported");

  }}

function type1(xhr){
            var docXML= xhr.responseText;
            var val_type = getSelectValue('identifiantDeMonSelect');
            var type = val_type+"";
            var str="{{ asset('Charts/Pie2D.swf') }}";
            var chart = new FusionCharts(str, "ChartId", "600", "400", "0", "0");
            chart.setXMLData(docXML);                               
            chart.render("chartdiv");
            }
function getSelectValue(selectId)
{
    var selectElmt = document.getElementById(selectId);
    return selectElmt.options[selectElmt.selectedIndex].value;
}

</script>

现在,当我简单地将 var str="{{ asset('Charts/Pie2D.swf') }}"; 替换为 "{{asset('Charts/'+type+'.swf') }}" 以动态更改图表类型时,我得到以下 symfony 错误:"Variable "type" does not exist in "。当我输入"{{ asset('Charts/"+type+".swf') }}"(我只是用“替换')时,我得到了页面,当我点击提交按钮时没有任何反应,并且在控制台(chrome的控制台)内我收到这个错误“GET http://127.0.0.1:8888/dashboard2/Symfony/web/Charts/&amp;quot;+type+&amp;quot;.swf 404 (Not Found)”。它需要它因为它是&amp;quot;+type+&amp;quot; 显然我需要帮助,我不知道这是连接问题还是与树枝和资产功能有关。提前致谢

【问题讨论】:

标签: javascript twig


【解决方案1】:

我想这是不可能的。您不能将 javascript vars 与 twig 混合使用,因为一个是客户端,另一个是服务器。

您可以创建一条路线来获取您的资产并在操作中使用资产功能,而不是在这里使用 {{asset}}。 然后你可以使用这个: https://github.com/FriendsOfSymfony/FOSJsRoutingBundle

或者像这样的廉价解决方法:

route = "{{ path('myassetroute', { 'pie': "PLACEHOLDER" }) }}";
route = route.replace("PLACEHOLDER", type);

【讨论】:

  • 非常感谢 :) 好吧,我想称之为“聪明的做事方式”而不是“廉价的解决方法”。