我想使用我在网上找到的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”,只有在我刷新页面之后。我该如何解决这个问题?
答案 0 :(得分:0)
正如艾哈迈德在评论中所说,session_start();
需要在脚本标签和任何其他html之前进行。我尝试了它,它没有刷新工作。感谢艾哈迈德的解决方案!