php - 在 php ajax 中加载更多结果的问题

标签 php jquery mysql ajax

我正在关注 PHP 上的 MVC 结构,这是我从 github 下载的。这对我很有帮助。

现在我已经实现了 Ajax 延迟加载功能,以便在用户点击时加载更多帖子(加载更多)。

我已经实现了这个结构,它工作完美,但我遇到了小问题。问题是,当没有可用记录时,它仍然显示加载更多内容,然后显示没有更多内容要加载

我尝试解决这个问题,但无法解决,这就是我来这里的原因。

我的代码有效:

index.php

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.0/jquery.min.js"></script>
<script type="text/javascript">
$(function () {
    $('.more_button').live("click", function () {
        var getId = $(this).attr("id");
        if (getId) {
            $("#load_more_" + getId).html('<img src="<?php echo URL; ?>public/img/load_img.gif" style="padding:10px 0 0 100px;"/>');
            $.ajax({
                type: "POST",
                url: "<?php echo URL; ?>home/loadSong",
                data: "getLastContentId=" + getId,
                cache: false,
                success: function (html) {
                    $("ul#load_more_ctnt").append(html);
                    $("#load_more_" + getId).remove();
                }
            });
        } else {
            $(".more_tab").html("<div class='all_loaded'>No More Content to Load</div>");
        }
        return false;
    });
});
</script>

<div class='main_div'>
    <ul class="load_content" id="load_more_ctnt">
        <?php foreach ($songs as $song) { $id = $song->id; ?>
            <li> <a href="#"><?php if (isset($song->artist)) echo $song->artist; ?></a> </li>
        <?php } ?>
    </ul>
    <div class="more_div">
        <a href="#">
            <div id="load_more_<?php echo $id; ?>" class="more_tab">
                <div class="more_button" id="<?php echo $id; ?>">Load More Content</div>
            </div>
        </a>
    </div>
</div>

home.php( Controller )

public function loadSong() {

        if(isset($_POST['getLastContentId'])) {
            // load model, perform an action on the model
            $getLastContentId=$_POST['getLastContentId'];
            $songs_model = $this->loadModel('HomeModel');
            $songs_model->loadmoreSong($getLastContentId);
        }
    }

homemodel.php(模型)

public function loadmoreSong($getLastContentId) {       

        if(isset($_POST['getLastContentId'])) {

            $getLastContentId=$_POST['getLastContentId'];

            $sql = "select id, artist, track, link from song WHERE id <".$getLastContentId." ORDER BY id DESC LIMIT 10";
            $query = $this->db->prepare($sql);
            $query->execute();
            $count = $query->fetchAll();

            if($count>0) {
                $id = "";
                for($i=0; $i<count($count); $i++){
                    $id = $count[$i]->id;
                    $message = $count[$i]->artist;
                ?>

                    <li>
                        <a href="#"><?php echo $message; ?></a>
                    </li>

                <?php
                    }
                ?>

                <a href="#">
                    <div id="load_more_<?php echo $id; ?>" class="more_tab">
                        <div id="<?php echo $id; ?>" class="more_button">Load More Content</div>
                    </div>
                </a>

            <?php
                }
            }
    }

我的现场演示链接:Load More Demo

希望你能理解我的问题。需要您的帮助来解决此问题。

谢谢。

最佳答案

只需编辑这段代码:

<a href="#">
 <div id="load_more_<?php echo $id; ?>" class="more_tab">
 <div id="<?php echo $id; ?>" class="more_button">Load More Content</div>
 </div>
</a>

对此:

<?php    
if($id!=""){
?>
<a href="#">
 <div id="load_more_<?php echo $id; ?>" class="more_tab">
 <div id="<?php echo $id; ?>" class="more_button">Load More Content</div>
 </div>
</a>
<?php
}
?>

关于php - 在 php ajax 中加载更多结果的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22787737/

相关文章:

php - 尝试使用 PHP 的 CURL 获取 cookie

javascript - GalleryView Jquery

jquery - 在不受信任的 URL 上调用 getJSON() 是否安全?

php - 在引导模式中打开表

Java:空值解析 XML 文件

php - 使用函数参数排序编号对 PHP 数组进行排序

php - 使用 codeigniter 中的电子邮件库发送垃圾邮件

php - 如何在 Yii 2 中更新大于所选记录的记录

javascript - 在实际更改选择框之前获取 onChange 值

php - 如何在达到限制时停止在 MySQL 表中插入记录