javascript - jQuery Ajax 两个相同的函数适用于其中一个而不适用于另一个

标签 javascript php jquery ajax

我正在制作一个评论系统,用户可以在帖子中评论某些内容,然后其他用户可以回复该评论。我做了一个评论功能,效果非常好。我还想要一个类似的函数来回复评论部分,所以我复制了相同的函数并对代码进行了一些更改,例如变量名称等。但它不起作用。当我写回复并按 Enter 键时,它会将我带到一个新行而不是提交。请帮助我。

// COMMENT UPDATE (WORKING)

$(document).on('keydown', '.commentarea', function(event) {
    var comtt = $(".commentarea").val();
    if(comtt!=''){
        if(event.keyCode == 13 && !event.shiftKey) {
            var id = $(this).attr('id');
            var status_id = id.replace("postcomment_", "");
            createComment(status_id);
            event.preventDefault();
        }
    }
});

function createComment(status_id){
  var comment = $('#postcomment_'+status_id).val();
  $.ajax({
      url: "post-comment.php",type: "POST",
      data: {comment : comment, statsid : status_id},
      success: function (data) {
        $("#showbox_"+status_id).append(data);
      },
      error: function () {
        alert("Ooops!! Problem Ocurred. Please try again later. If problem persists, please contact support!");
      },
      complete: function(xhr) {
        $('#postcomment_'+status_id).val('');
      }
  })
}

// REPLY TO COMMENT (SAME FUNCTION BUT NOT WORKING)

$(document).on('keydown', '.replyarea', function(event) {
    var comtr = $(".replyarea").val();
    if(comtr!=''){
        if(event.keyCode == 13 && !event.shiftKey) {
            var rid = $(this).attr('id');
            var commentId = rid.replace("replycomment_", "");
            createReply(commentId);
            event.preventDefault();
        }
    }
});

function createReply(commentId){
  var creply = $('#replycomment_'+status_id).val();
  $.ajax({
      url: "post-replies.php",type: "POST",
      data: {creply : creply, cmtid : commentId},
      success: function (data) {
        $("#showreply_"+commentId).append(data);
      },
      error: function () {
        alert("Ooops!! Problem Ocurred. Please try again later. If problem persists, please contact support!");
      },
      complete: function(xhr) {
        $('#replycomment_'+commentId).val('');
      }
  })
}

PHP 部分:

<?php while($get_stf = $get_stq->fetch()){ extract($get_stf); // fetch posts ?>

<?php while($fetch_cmts = $get_cmtq->fetch()){ extract($fetch_cmts); // fetch comments?>

 <!-- Reply to comments form -->

<form method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>" class="full-width" id="cmt_form_id_<?php echo $cmt_id; ?>">

<input type="hidden" name="comment_id" value="<?php echo $cmt_id; ?>" id="cmtsid_<?php echo $cmt_id; ?>" />

<textarea name="reply" placeholder="Give a reply..." class="reply-comment-field replyarea" id="replycomment_<?php echo $cmt_id; ?>"></textarea>

</form>
<!-- End Reply to comments form -->

<?php } ?>

<!-- Comment form -->
<form method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>" class="full-width" id="cmt_form_id_<?php echo $cmt_id; ?>">

<input type="hidden" name="comment_id" value="<?php echo $cmt_id; ?>" id="cmtsid_<?php echo $cmt_id; ?>" />

<textarea name="reply" placeholder="Give a reply..." class="reply-comment-field replyarea" id="replycomment_<?php echo $cmt_id; ?>"></textarea>

</form>
<!-- End Comment form -->

<?php } ?>

两个功能是相同的。但是用于评论的一个工作正常,而用于回复评论的一个则无法工作。当我像 FACEBOOK 一样编写一些文本后在回复评论表单中按 Enter 键时,它应该提交表单并插入数据。请帮忙。

最佳答案

您的评论破坏了代码:

更改此:

<!-- Reply to comments form -- >

为此:

 <!-- Reply to comments form -->

并更新。

关于javascript - jQuery Ajax 两个相同的函数适用于其中一个而不适用于另一个,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40271607/

相关文章:

javascript - Symfony Ajax 请求错误 500

php - 安装wamp后无法加载phpmyadmin

php - Laravel Sail 无法运行 artisan migrate

javascript - 如何调试和修复这个问题?

javascript - 计时器可由多个用户查看

javascript - 如果 session 中的属性不为 null 或默认值,则运行/打印 javascript Razor ASP.NET MVC

php - PHP 中的串联 : missing white space

jquery - CSS/JQuery AddRemove 类需要点击 2 次?

javascript - jQuery 选择器 .not() 不工作

javascript - 如何使用 OnClick 事件设置 Jquery Mobile 导航