php - 从数据库加载更多项目 ~ Infinite Scroll

标签 php jquery mysql ajax infinite-scroll

我是 ajax/php 的新手,所以我想找出最好的方法。

我有一个包含 1500 个项目的 sql 数据库,我正在加载到我的页面中。我想将 30 个项目加载到页面中,然后当用户到达网页底部时,我希望它再加载 30 个项目。

到目前为止,我的网页上显示了 30 个项目,并有一个下拉菜单可以过滤这些项目。我还有一个在用户到达页面底部时触发的函数。

任何人都可以帮助我使用 PHP 脚本来完成这项工作并加载更多项目吗?我正在使用的代码如下。

谢谢

HTML

<section id="filters">
    <select name="entries"  onchange="filterEntries()">
        <option value="*">show all</option>
        <option value=".item323">323</option>
        <option value=".item266">266</option>
        <option value=".item277">277</option>
        <option value=".item289">289</option>
    </select>
</section> <!-- #filters -->

<div id="entries" class="clearfix">
    <div class="ajaxloader"><img src="<?php bloginfo('template_url'); ?>/ajax_load.gif" alt="loading..." /></div><!--ajaxloader-->
</div><!--entries-->
<div class="ajaxloader"><img src="<?php bloginfo('template_url'); ?>/ajax_load.gif" alt="loading..." /></div><!--ajaxloader-->

Jquery

$(document).ready(function () {
    loadData();
    //Hide Loader for Infinite Scroll
    $('div.ajaxloader').hide();

});

function loadData () {
//Show Loader for main content
    $('#entries .ajaxloader').show();
//Pull in data from database
if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari
        "use strict";
        xmlhttp=new XMLHttpRequest(); 
    }
    else {// code for IE6, IE5
        xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
    }
    xmlhttp.onreadystatechange=function() {
        if (xmlhttp.readyState===4 && xmlhttp.status===200) {    
        document.getElementById("entries").innerHTML=xmlhttp.responseText;
        //Fire filter function once data loaded
            filterEntries();
            //Hide Loader for main content once loaded
            $('#entries .ajaxloader').hide();
    }
    }
    xmlhttp.open("POST","<?php bloginfo('template_url'); ?>/getentries.php?$number",true);
    xmlhttp.send();
};


//Isotope filter
function filterEntries () {
    var $container = $('#entries');
       $select = $('#filters select');

    $container.isotope({
        itemSelector : '.item'
    });

    $select.change(function() {
    var filters = $(this).val();

    $container.isotope({
            filter: filters
    });
});
};

$(window).scroll(function () {
    if ($(window).scrollTop() >= $(document).height() - $(window).height() - 10) {
    $('div.ajaxloader').show('slow');

        //alert("Function to load more entries");

    }
});

PHP

<?php
    //Connect to Database
    $con = mysql_connect("localhost", "root", "root");
    if (!$con) {
        die('Could not connect: ' . mysql_error());
    }
    mysql_select_db("awards", $con);


    $sql="SELECT * FROM entry WHERE  status = 'registered' ORDER BY `entry_id` LIMIT 0, 30";

    $result = mysql_query($sql);


    while($row = mysql_fetch_array($result)) {
        //Get award cat ids
        $awardcat =  $row['awards_subcategory_id']  ;

        print "<div class='item item$awardcat clearfix'>";//add award cat id to each div
        print '<img class="image" src="http://localhost:8888/awardsite/wp-content/themes/award/placeholder.jpg" />';
        print "<p > Studio: " . $row['studio'] . "</p>";
        print "<p class='client'> Client: " . $row['client'] . "</p>";
        print "<p class='description'> Description: " . $row['description'] . "</p>";
        print "<p class='solutionprocess'> Solution Process: " . $row['solution_process'] . "</p>";
        print "</div>";

    }





    mysql_close($con);
?> 

最佳答案

这是一个相当复杂的问题。在尝试从头开始编写您自己的变体之前,我建议您看一下 Infinite Scroll jQuery Plugin .如果这不能解决问题,这里有一个可能的解决方案:

Javascript

$(document).ready(function () {
    loadData( 0 );
    //Hide Loader for Infinite Scroll
    $('div.ajaxloader').hide();

});

function loadData ( last_id ) {
    var $entries = $('#entries'),
        $loader = $('.ajaxloader', $entries).show();
    $.get( '/getentries.php', { last_id : last_id }, function( data ) {
        $entries.append( data ).append( $loader.hide() );
        filterEntries();
    });
};


//Isotope filter - no changes to this code so I didn't include it

$(window).scroll(function () {
    if ($(window).scrollTop() >= $(document).height() - $(window).height() - 10) {
        $('div.ajaxloader').show('slow');
        loadData( $( '#entries item:last' ).data('id') )
    }
});

PHP

<?php
//Connect to Database
$con = new mysqli( 'localhost', 'root', 'root', 'awards' );
if( $con->connect_errno ) {
    die( 'Could not connect:' . $con->connect_error );
}

$last_id = isset( $_GET['last_id'] ) ? (int)$_GET['last_id'] : 0; 
$stmt = $con->prepare( 'SELECT * FROM entry WHERE status = "registered" AND entry_id > (?) ORDER BY entry_id LIMIT 0, 30' );
$stmt->bind_param( 'i', $last_id );
$stmt->execute();

$result = $stmt->get_result();    
while( $row = $result->fetch_assoc() ) {
    //Get award cat ids
    $awardcat = $row['awards_subcategory_id'];

    print "<div class='item item$awardcat clearfix' data-id='" . $row['entry_id'] . "'>";//add award cat id to each div
    print '<img class="image" src="http://localhost:8888/awardsite/wp-content/themes/award/placeholder.jpg" />';
    print "<p > Studio: " . $row['studio'] . "</p>";
    print "<p class='client'> Client: " . $row['client'] . "</p>";
    print "<p class='description'> Description: " . $row['description'] . "</p>";
    print "<p class='solutionprocess'> Solution Process: " . $row['solution_process'] . "</p>";
    print "</div>";

}
$con->close();

Javascript 代码将 AJAX GET 请求发送到 php 脚本,其中包含列表中显示的最后一个条目的 ID。然后 PHP 脚本返回该 ID 之后的 30 个条目。原始的 Javascript 文件中有一些 PHP 代码。我删除了它,因为我不知道它的目的是什么(你是从 PHP 脚本输出 JS 吗?)。此外,整个 XMLHttpRequest 代码可以缩短为 $.get() 函数。无论如何你都在使用 jQuery,所以你不需要重新发明轮子。我使用 data-id 属性来传输条目 ID。这是 HTML5 特定的属性。如果您不想使用它,只需使用 id 即可,但请记住,id 不能以数字开头 - 您应该在它前面加上一个字母。

在 PHP 脚本中,我使用了 mysqli 而不是 mysql_* 函数。从现在开始,您应该使用 mysqliPDO,因为它们比(现已弃用)mysql_* 更可靠、更安全。您的 PHP 安装很可能已经包含这些扩展。请注意,我没有处理数据库查询错误。您可以自己编写该代码。如果您遇到其他类型的错误,请在此处发布它们,我会尝试修复它们。

关于php - 从数据库加载更多项目 ~ Infinite Scroll,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11878365/

相关文章:

javascript - 保持固定的 div 与另一个 div 的特定距离,即使在调整大小时也是如此

php - nginx 可以提供 PHP 缓存的文件吗?

javascript - Google Analytics 事件跟踪 JS 在开发控制台中运行/工作,但不能从 ex 文件中运行/工作

php - SQLSTATE[HY093] : Invalid parameter number: no parameters were bound, 但提供了参数

javascript - JS 脚本 - if 语句忽略 jQuery 代码

php - 可排序数据 PHP MYSQL

mysql - 具有 2 个连接的 SQL 查询

mysql - SQL 自连接返回特定行

javascript - PHP 结果到 AJAX 比较数组问题

php - mpdf 列宽未固定并随数据增加