通过AJAX加载PHP会话?

时间:2015-01-26 17:27:36

标签: php jquery ajax session infinite-scroll

我想使用我在网上找到的AJAX脚本创建一个无限滚动,以便在它到达底部时加载我的PHP页面。

第一页将使用将通过ajax加载的php页面打印的会话。

我已经成功完成了这项工作,但我注意到这只是第一次不起作用,只是在我刷新页面一次之后,就好像它无法第一次加载会话一样。我正在使用私人会话测试这个,所以我可以模拟新用户的样子。

所以这里我有index.php:

<script src="jquery-1.7-min.js"></script>
<?php
    session_start();
    $_SESSION['test1'] = '<br><br><br>content to be loaded';
?>
<div id="postswrapper">
    <div class="item">content</div>
    ...
    <div id="loadmoreajaxloader" style="display:none;"><center><img src="ajax-loader.gif" /></center></div>
</div>
---- footer content ----
<script type="text/javascript">
$(window).scroll(function()
{
    if($(window).scrollTop() == $(document).height() - $(window).height())
    {
        $('div#loadmoreajaxloader').show();
        $.ajax({
        url: "more-data.php",
        success: function(html)
        {
            if(html)
            {
                $("#postswrapper").append(html);
                $('div#loadmoreajaxloader').hide();
            }else
            {
                $('div#loadmoreajaxloader').html('<center>No more posts to show.</center>');
            }
        }
        });
    }
});
</script>

这里有更多-data.php:

<?php
    session_start();
    print_r ($_SESSION['test1']);
?>

我需要在第一页上使用session,因为我在ajax启动之前使用它来加载更多内容。所以删除会话不是一种选择。

看起来会话第一次没有加载“more-data.php”,只有在我刷新页面之后。我该如何解决这个问题?

1 个答案:

答案 0 :(得分:0)

正如艾哈迈德在评论中所说,session_start();需要在脚本标签和任何其他html之前进行。我尝试了它,它没有刷新工作。感谢艾哈迈德的解决方案!