小编典典

Symfony2在AJAX调用上返回空JSON,而变量不为空

ajax

问题

我正在尝试获得AJAX响应,因此我可以摆弄它以使表单更易于使用。当我使控制器(下面的代码)使用返回正常响应时var_dump(),我得到了对象的输出,因此我知道查询没有错(我使用ID
1进行查询调试)。但是,当我使用返回输出时json_encode(),我只会得到一个空的JSON文件。

视图中的HTML表单

<div id="content">
    <form id="myForm" action="{{path('snow_ajax')}}" method="POST" >
        Write your name here:
        <input type="text" name="name" id="name_id" value="" /><br />
        <input type="submit" value="Send" />
    </form>
</div>

同一视图中的脚本

<script type="text/javascript">
    $(document).ready(function() {

        $("#myForm").submit(function(){
            var url=$("#myForm").attr("action");

            $.post(url,{
                formName:"ajaxtest",
                other:"attributes"
            },function(data){

                if(data.responseCode==200 ){
                    alert("Got your json!");
                }
                else{
                    alert("something went wrong :(");
                }
            });
            return false;
        });
    });
</script>

控制器响应正常(工作)

public function ajaxAction()
{

    $location = $this->getDoctrine()->getRepository('SnowFrontBundle:Location')
        ->find(1);

    $output = var_dump($location);

    return $output;
}

具有AJAX响应的控制器(无效,返回空JSON)

public function ajaxAction()
{

    $location = $this->getDoctrine()->getRepository('SnowFrontBundle:Location')
        ->find(1);

    return new Response(json_encode($location), 200);
}

有人可以帮我吗?这真让我发疯!


阅读 208

收藏
2020-07-26

共1个答案

小编典典

我设法通过使用Doctrine2的实体管理器来修复它,以将结果存储在数组中,然后我将其编码为JSON。我不确定这是否是最干净的方法(根据我的IDE,getEntityManager()似乎已被弃用),但目前效果良好。

public function ajaxAction()
{
    $em = $this->getDoctrine()->getEntityManager();
    $query = $em->createQuery('SELECT l FROM Snow\FrontBundle\Entity\Location l WHERE l.id=:id');
    $query->setParameter('id', 1);
    $result = $query->getArrayResult();

    return new Response(json_encode($result), 200);
}
2020-07-26