【问题标题】:comment system issue : comment disappear when refresh the page评论系统问题:刷新页面时评论消失
【发布时间】:2014-07-11 16:34:34
【问题描述】:

我正在尝试制作一个简单的评论系统,它工作正常,它显示 cmets,但问题是当我刷新页面时,所有 cmets 都消失了。 这是我的 php 代码:

<?php
   include_once('con.php');
   if(isset($_POST['content']))
   {
      $content=mysqli_real_escape_string($con, $_POST['content']);
      mysqli_query($con, "insert into message (msg) values ('$content')");
   }
   $result= mysqli_query($con, "SELECT msg, id FROM message WHERE seen = 1 order by id desc");
   while($row = mysqli_fetch_array($result))
   {
      mysqli_query($con,"UPDATE message SET seen = 0 ");
      $msg = $row['msg'];
      ?> 
      <div class="hata"><?php echo $msg ;?></div> 
   <?php
   }
   ?>
<div class="hata"><?php echo $msg ;?></div>  <?php } ?>

这是jquery代码:

$(function() {
   $(".submit_button").click(function() {
      var textcontent = $("#content").val();
      var dataString = 'content='+ textcontent;
      if(textcontent=='')
      {
         alert("Enter some text..");
         $("#content").focus();
      }
      else
      {
         $.ajax({
            type: "POST",
            url: "action.php",
            data: dataString,
            cache: true,
            success: function(html){
               $("#msg_show").after(html);
               document.getElementById('content').value='';
               $("#content").focus();
            }  
         });}
      return false;
   });
});

正如我之前所说,脚本工作正常,但唯一的问题是当我刷新页面时,所有 cmets 都会从索引页面中消失,

【问题讨论】:

    标签: php jquery html


    【解决方案1】:

    这些消息被标记为 see=0。因此查询“where seen=1”不会再次返回消息,只会返回带有 flag seen=1 的新消息。使用您的代码,每条消息都只查询一次。 如果您不想在结果中保留消息,请删除该行

    mysqli_query($con,"UPDATE message SET seen = 0 ");
    

    【讨论】:

    • 当我删除该行时,每当我添加新评论时,它会给我旧评论和旧评论 + 新评论,我的意思是它给了我两次旧 cmets。而且当我刷新页面时,所有 cmets 都会消失。
    • 消息添加到数据库的频率如何?我的意思是,当你只是重新加载页面时,$_POST['content'] 仍然是请求的一部分,并且再次添加了消息,所以你会得到两次?
    • 我知道但我不知道解决办法
    • 您至少应该执行“发布后重定向”,以避免多次添加消息。这加上删除标志会显示所有消息一次,并且在再次请求时它们不会被标记为“不可见”。其他一切都需要更好的代码/路由。对不起。
    猜你喜欢
    • 2013-03-22
    • 1970-01-01
    • 1970-01-01
    • 2011-08-16
    • 2018-05-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多