无限滚动ajax jquery

时间:2012-06-29 17:43:07

标签: javascript jquery ajax symfony

我正在尝试实现无限滚动选项。我正在使用symfony2框架。

html看起来像这样:

<div id='more' >Loading...</div>
<div id='no-more' >No more results</div>
<div id='result'></div>

控制器:

if($request->isXmlHttpRequest()){
   $appResult = THIS IN AN ARRAY WITH ALL THE RESULTS ......
   $return=array("responseCode"=>400, "appResult"=>$appResult);
   $return=json_encode($return);
   return new Response($return,200,array('Content-Type'=>'application/json'));
}

和javascript:

<script type="text/javascript">
        var page = 1;


        $(window).scroll(function () {
            $('#more').hide();
            $('#no-more').hide();


            if($(window).scrollTop() + $(window).height() > $(document).height() - 200) {
                $('#more').css("top","400");
                $('#more').show();

            }
            if($(window).scrollTop() + $(window).height() == $(document).height()) {

                $('#more').hide();
                $('#no-more').hide();

                page++;

                var data = {
                    page_num: page
                };

                var actual_count = 30;

                if((page-1)* 12 > actual_count){
                    $('#no-more').css("top","400");
                    $('#no-more').show();
                }else{
                     $.ajax({
                        type: "POST",
                        url: "{{ path('login') }}",
                        data:data,
                        success: function(res) {


WHAT I DO HERE????


                        }
                    });
                }

            }


        });

</script>

代码工作正常,它发送请求并接收包含所有结果的响应数组。但我不知道如何处理这些结果,我怎样才能在结果div中打印它们?

1 个答案:

答案 0 :(得分:0)

我假设“res”正在返回HTML并且您希望该数据进入#result div?如果是这样,请将其置于成功函数中:

$('#result').html($(res));

或者只是

$('#result').html(res);

如果你返回的“res”是JSON,你将不得不以某种方式解析它然后将它放在div中。你能告诉我们res的结果是什么吗?

编辑:由于它是JSON,您可能需要执行以下操作:

var data = $.parseJSON(res);
$.each(data, function(index, value) {
    var currentHTML = $('#result').html();
    $('#result').html(currentHTML + this.description);
});