我正在创建一个事件插件,其中每个事件都有一个评论部分。我可以保存每条评论,但我现在遇到的问题是我被带到了空白的 admin-ajax.php 。提交表单后,我想留在同一页面上并加载结果。我知道,通过将表单操作设置为 admin-ajax.php,它将最终出现在该页面上,但我尝试了通过 Google 搜索找到的不同方法,这是我能够做到的唯一方法让它保存到数据库中。我的代码如下。
表格
<form action="<?php echo site_url() ?>/wp-admin/admin-ajax.php" method="POST" id="comment_form">
<textarea name="comment" id="comment" class="commentbox" rows="5" cols="120" required></textarea><br />
<input type="hidden" name="eventid" id="eventid" value="<?php echo $id; ?>" />
<input type="hidden" name="userid" id="userid" value="<?php echo $userid; ?>" />
<input type="hidden" name="action" value="commentform">
<button class="commentbtn">Add Comment</button>
</form>
<div id="response"></div>
jQuery
<script>
jQuery(function($){
$('#commentform').submit(function(){
var commentform = $('#commentform');
$.ajax({
url:commentform.attr('action'),
data:commentform.serialize(), // form data
type:commentform.attr('method'), // POST
beforeSend:function(xhr){
commentform.find('button').text('Processing...');
},
success:function(data){
commentform.find('button').text('Add Comment');
$('#response').html(data); // insert data
}
});
return false;
});
});
</script>
PHP 函数
add_action('wp_ajax_commentform', 'comment_submit');
add_action('wp_ajax_nopriv_commentform', 'comment_submit');
function comment_submit() {
global $wpdb;
$eventid = $_POST["eventid"];
$userid = $_POST["userid"];
$comment = $_POST["comment"];
date_default_timezone_set("America/New_York");
$date = date('Y-m-d H:i:s');
$inserttable = $wpdb->prefix . "event_comments";
$data = array(
'eventid' => $eventid,
'userid' => $userid,
'content' => $comment,
'datesaved' => $date,
);
$wpdb->insert($inserttable, $data);
die;
}
抱歉我无法评论。
阅读您的代码,您正在查找的元素不存在: 将 comment_form 替换为 commentform。
$('#commentform').submit(function(){
var commentform = $('#commentform');
但是你的id属性是id="**comment_form">
<form ... id="comment_form">
我想通了。我忘记添加 event.preventDefault();停止加载表单。