wordpress网站Ajax留言评论+自定义评论字段

在WordPress中,您可以使用Ajax来实现无刷新的留言功能,并添加自定义评论字段。以下是一个简化的例子,展示了如何添加一个简单的自定义字段并通过Ajax提交。

  1. 添加自定义字段到评论表单:

在主题的functions.php文件中添加以下代码来添加自定义字段:




function my_custom_comment_field($fields) {
    $fields['my_field'] = '<p class="comment-form-my-field"><label for="my_field">自定义字段</label><input id="my_field" name="my_field" type="text" value=""></p>';
    return $fields;
}
add_filter('comment_form_fields', 'my_custom_comment_field');
  1. 创建Ajax处理脚本:

在主题的functions.php文件中添加以下代码来处理Ajax请求:




function my_ajax_comment_script() {
    wp_enqueue_script('my-ajax-comment', get_template_directory_uri() . '/js/my-ajax-comment.js', array('jquery'));
    wp_localize_script('my-ajax-comment', 'myAjax', array(
        'url' => admin_url('admin-ajax.php'),
        'nonce' => wp_create_nonce('my_nonce')
    ));
}
add_action('wp_enqueue_scripts', 'my_ajax_comment_script');
 
add_action('wp_ajax_my_ajax_comment', 'my_ajax_comment_callback');
add_action('wp_ajax_nopriv_my_ajax_comment', 'my_ajax_comment_callback');
function my_ajax_comment_callback() {
    check_ajax_referer('my_nonce', 'nonce');
 
    $comment_data = [
        'comment_post_ID' => $_POST['post_id'],
        'comment_content' => $_POST['comment_content'],
        'comment_author' => $_POST['author'],
        'comment_author_email' => $_POST['email'],
        'comment_author_url' => $_POST['url'],
        'comment_type' => 'ajax',
        'user_id' => get_current_user_id(),
        'my_field' => $_POST['my_field']
    ];
 
    $comment_id = wp_new_comment(array_merge($_POST, $comment_data));
    do_action('set_comment_cookies', $comment_id);
 
    $comment = get_comment($comment_id);
    $data = wp_load_commentsajax_script_data($comment);
    wp_die(json_encode($data));
}
  1. 创建Ajax请求的JavaScript文件:

在主题的js文件夹中创建my-ajax-comment.js文件,并添加以下代码:




jQuery(document).ready(function($) {
    $('#commentform').on('submit', function(e) {
        e.preventDefault();
        var formData = $(this).serializeArray();
        formData.push({ name: 'action', value: 'my_ajax_comment' });
 
        $.post(myAjax.url, formData, function(data) {
            $('#comments').append(data[0]);
            $('#comment_content').val('');
            $('#my_field').val('');
        });
    });
});

确保替换get_template_directory_uri() . '/js/my-ajax-comment.js'中的路径,以指向您的自定义JavaScript文件。

这个简单的例子展示了

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日