0

更新:

我想制作一个加载更多的ajax按钮,我希望它从一个php文件中加载数据,该文件将从数据库中提取数据。

我设法让它只加载一次,但是当我点击新的更多按钮时它不起作用。

这是Javascript:

$(document).ready(function(){
    $(".more").click(function(){
        var ID = $(this).attr("id");
        if(ID) {
            $("#more"+ID).html('<img src="moreajax.gif" />');

            $.ajax({
                type: "POST",
                url: "more.php",
                data: "lastimg="+ ID,
                cache: false,
                success: function(html){
                    $("div#updates").append(html);
                    $("#more"+ID).remove(); // removing old more button
                }
            });
        } else {
            $(".morebox").html('The End');// no results
        }

        return false;
    });
});

还有更多.php

$lastimg = mysql_real_escape_string($_POST['lastimg']);

$result = $mmhclass->db->query("SELECT * FROM `file_storage` WHERE `is_private` = '0' AND `file_id` < '$lastimg' ORDER BY `file_id` DESC LIMIT 10;", array(MYSQL_FILE_STORAGE_TABLE));

while($row=mysql_fetch_array($result))
{
$file_id = $row['file_id'];
$filename = $row['filename'];
?>
    <li>
        <?php echo $filename; ?>
    </li>
<?php
}
?>
<div id="more<?php echo $file_id; ?>" class="morebox">
    <a href="#" class="more" id="<?php echo $file_id; ?>">more</a>
</div>
4

2 回答 2

3

它只工作一次,因为在你的 ajax 完成后,.more页面上的元素将是新的,所以click你附加到它的事件处理程序不再工作了。

您必须使用事件委托:

$('body').on('click', '.more', function () {
    // your code
});
  • 注:jQuery 1.7+必填。

参考:

  • .on()- jQuery API 文档
于 2013-06-05T03:25:29.660 回答
0

我想你可以使用 jQuery live函数

$(".more").live("click", function(){ 

// Code here
});
于 2013-06-05T03:32:04.620 回答