0

こんにちは私は、ユーザーが[さらにロード]ボタンをクリックすると、ajaxが新しいコンテンツを要求してユーザーに表示するというスクリプトを持っていますが、すべてのコンテンツがロードされ、ユーザーが[さらにロード]ボタンをクリックすると、バグが発生し、複数のロードが繰り返し表示されるという問題がありますmoreボタン。以下は私のコードです。これを解決する方法を知る必要があります。ロードするコンテンツがない場合は、ボタンを無効にする必要があります。ありがとうございます。

ajax_more.php

 <?php
include("config.php");


if(isSet($_POST['lastmsg']))
{
$lastmsg=$_POST['lastmsg'];
$result=mysql_query("select * from messages where mes_id<'$lastmsg' limit 3");
$count=mysql_num_rows($result);
while($row=mysql_fetch_array($result))
{
$msg_id=$row['mes_id'];
$message=$row['msg'];
?>


<li>
<?php echo $message; ?>
</li>


<?php
}


?>

<div id="more<?php echo $msg_id; ?>" class="morebox">
<a href="#" id="<?php echo $msg_id; ?>" class="more">more</a>
</div>

<?php
}
?>

loadmore.php

<?php
include('config.php');

?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<title>Twitter Style load more results.</title>
<link href="frame.css" rel="stylesheet" type="text/css">
<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
$('.more').live("click",function() 
{
var ID = $(this).attr("id");
if(ID)
{
$("#more"+ID).html('<img src="moreajax.gif" />');

$.ajax({
type: "POST",
url: "ajax_more.php",
data: "lastmsg="+ ID, 
cache: false,
success: function(html){
$("ol#updates").append(html);
$("#more"+ID).remove();
}
});
}
else
{
$(".morebox").html('The End');

}


return false;


});
});

</script>
<style>
body
{
font-family:Arial, 'Helvetica', sans-serif;
color:#000;
font-size:15px;

}
a { text-decoration:none; color:#0066CC}
a:hover { text-decoration:underline; color:#0066cc }
*
{ margin:0px; padding:0px }
ol.timeline
    { list-style:none}ol.timeline li{ position:relative;border-bottom:1px #dedede dashed; padding:8px; }ol.timeline li:first-child{}
    .morebox
    {
    font-weight:bold;
    color:#333333;
    text-align:center;
    border:solid 1px #333333;
    padding:8px;
    margin-top:8px;
    margin-bottom:8px;
    -moz-border-radius: 6px;-webkit-border-radius: 6px;
    }
    .morebox a{ color:#333333; text-decoration:none}
    .morebox a:hover{ color:#333333; text-decoration:none}
    #container{margin-left:60px; width:580px }

</style>
</head>

<body>
<div style="padding:4px; margin-bottom:10px; border-bottom:solid 1px #333333; "><h3>Tutorial Link <a href="http://9lessons.blogspot.com/2009/12/twitter-style-load-more-results-with.html">Click Here</a></h3></div>
<div id='container'>
<ol class="timeline" id="updates">
<?php
$sql=mysql_query("select * from messages  LIMIT 3");
while($row=mysql_fetch_array($sql))
{
$msg_id=$row['mes_id'];
$message=$row['msg'];
?>
<li>
<?php echo $message; ?>
</li>
<?php } ?>
</ol>
<div id="more<?php echo $msg_id; ?>" class="morebox">
<a href="#" class="more" id="<?php echo $msg_id; ?>">more</a>
</div>
</div>

</body>
</html>
4

3 に答える 3

2
<?php
include("config.php");

$count=0;
$done=false;
if(isSet($_POST['lastmsg']))
{
$lastmsg=$_POST['lastmsg'];
$result=mysql_query("select * from messages where mes_id<'$lastmsg' limit 3");
$check=mysql_result(mysql_query("select mes_id from messages ORDER BY mes_id ASC limit 1"));
$count=mysql_num_rows($result);
while($row=mysql_fetch_array($result))
{
$msg_id=$row['mes_id'];
$message=$row['msg'];
if($row['mes_id']==$check){$done=true;}
$count++;
?>


<li>
<?php echo $message; ?>
</li>


<?php
}

if($count>0 && !$done){
?>

<div id="more<?php echo $msg_id; ?>" class="morebox">
<a href="#" id="<?php echo $msg_id; ?>" class="more">more</a>
</div>

<?php
}
}
?>

説明:より多くのリンクを無条件に出力していました。変更が加えられると、スクリプトは、さらにリンクを出力する前に、テーブルから0を超えるメッセージがロードされているかどうかを確認します。また、現在のバッチが最後であるかどうかを確認し、最後である場合はそれ以上のdivを出力しないように更新しました。

于 2012-10-13T11:16:01.440 に答える
1

このコードを試してください。

   $.ajax({
**$("#load_buton").attr("disabled","disabled");**
    type: "POST",
    url: "ajax_more.php",
    data: "lastmsg="+ ID, 
    cache: false,
    success: function(html){
    $("ol#updates").append(html);
    $("#more"+ID).remove();
**$("#load_buton").removeAttr("disabled");**
    });
于 2012-10-13T11:33:25.067 に答える
0

phpセクションで、返された行サイズの数が0より大きい場合にのみ、[その他]ボタンを表示します

エッジケース:

  1. データベーステーブルのサイズがn行増えると、[その他]をクリックするたびにnレコードが繰り返されます。
  2. 上記と同じですが、レコードが削除されると、レコードを見逃してしまいます

セキュリティ上の問題:

  1. 最後のメッセージ投稿フィールドに「0';メッセージの切り捨て;-」を送信することによるSQLインジェクション
  2. クロスサイトスクリプティング-ユーザーがHTML/JavaScriptを使用してメッセージを送信できる場合、それらはエスケープせずにコンテンツで返されます。

上記の両方の場合で、を使用します。MySQLエスケープ文字列(http://php.net/manual/en/function.mysql-real-escape-string.php)、またはmysqliを使用し、htmlentities(http://php.net/manual/en/function .htmlentities.php

于 2012-10-13T11:25:57.577 に答える