亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

WordPress中利用AJAX技術進行評論提交的實現示例

2024-09-01 08:33:40
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了WordPress中利用AJAX技術進行評論提交的實現示例,整個處理的關鍵點在于文中的ajax_comment函數,需要的朋友可以參考下
 

一直對 WordPress 的 Ajax 交互研究感興趣,也一直很關注于這方面的技術,談到 WordPress Ajax 就不得不談到評論 Ajax提交,作為一個博客、論壇評論的 Ajax 提交不僅可以改善用戶體驗,還可以大幅縮減服務器開支,畢竟輸出單條評論內容比重新組織輸出一個頁面要簡單的多。 雖說現在訪問量一直比較低,不存在服務器壓力的問題,但一向注重用戶體驗的我,當然不能放棄這么一個提升用戶體驗的機會。今天抽了一下午的空,把這個主題的 Ajax 評論提交初步完成了。

直接開門見山,直接上代碼:(原理及思路在最后)
根據自己主題不同結構,以下代碼請自行調整。

WordPress Ajax 提交評論 PHP 代碼
在主題 function.php 文件中加入如下部分。

//以下大部分代碼出自 yinheli 經由該部分代碼,排除部分錯誤、優化精簡得出以下代碼。//yinheli博客不做了,所以這里就不給鏈接了。//Edited by XiangZi DEC.17TH 2011function fail($s) {//虛擬錯誤頭部分  header('HTTP/1.0 500 Internal Server Error');  echo $s;  exit;}function ajax_post_comment_slow (){ fail('用不用說這么快?想好了再說!');}//評論太快輸出代碼。add_filter('comment_flood_trigger','ajax_post_comment_slow', 0);//掛一個評論太快,返回內容的鉤子function ajax_comment(){// Ajax php 響應部分代碼if($_POST['action'] == 'ajax_comment') {  global $wpdb, $db_check;    // Check DB    if(!$wpdb->dbh) {      echo('Our database has issues. Try again later.');  die();    } nocache_headers();$comment_post_ID = (int) $_POST['comment_post_ID']; $status = $wpdb->get_row("SELECT post_status, comment_status FROM $wpdb->posts WHERE ID = '$comment_post_ID'");if ( empty($status->comment_status) ) {//這一套判斷貌似抄的 wp 源代碼 。詳見:include/comment.php  do_action('comment_id_not_found', $comment_post_ID);  fail('The post you are trying to comment on does not currently exist in the database.');} elseif ( 'closed' == $status->comment_status ) {  do_action('comment_closed', $comment_post_ID);;  fail('Sorry, comments are closed for this item.');} elseif ( in_array($status->post_status, array('draft', 'pending') ) ) {  do_action('comment_on_draft', $comment_post_ID);  fail('The post you are trying to comment on has not been published.');}$comment_author    = trim(strip_tags($_POST['author']));$comment_author_email = trim($_POST['email']);$comment_author_url  = trim($_POST['url']);$comment_content   = trim($_POST['comment']);// If the user is logged in$user = wp_get_current_user();if ( $user->ID ) {  $comment_author    = $wpdb->escape($user->display_name);  $comment_author_email = $wpdb->escape($user->user_email);  $comment_author_url  = $wpdb->escape($user->user_url);  if ( current_user_can('unfiltered_html') ) {    if ( wp_create_nonce('unfiltered-html-comment_' . $comment_post_ID) != $_POST['_wp_unfiltered_html_comment'] ) {      kses_remove_filters(); // start with a clean slate      kses_init_filters(); // set up the filters    }  }} else {  if ( get_option('comment_registration') )    fail('火星人?注冊個?');}$comment_type = '';if ( get_option('require_name_email') && !$user->ID ) {  if ( 6> strlen($comment_author_email) || '' == $comment_author )    fail('Oopps,名字[Name]或郵箱[email]不對。');  elseif ( !is_email($comment_author_email))    fail('Oopps,郵箱地址[Email]不對。');}if ( '' == $comment_content )  fail('是不是應該寫點什么再提交?');// Simple duplicate check$dupe = "SELECT comment_ID FROM $wpdb->comments WHERE comment_post_ID = '$comment_post_ID' AND ( comment_author = '$comment_author' ";if ( $comment_author_email ) $dupe .= "OR comment_author_email = '$comment_author_email' ";$dupe .= ") AND comment_content = '$comment_content' LIMIT 1";if ( $wpdb->get_var($dupe) ) {  fail('評論重復了!有木有!');}$commentdata = compact('comment_post_ID', 'comment_author', 'comment_author_email', 'comment_author_url', 'comment_content', 'comment_type', 'user_ID');if( !$user->ID ){ $result_set = $wpdb->get_results("SELECT display_name, user_email FROM $wpdb->users WHERE display_name = '" . $comment_author . "' OR user_email = '" . $comment_author_email . "'"); if ($result_set) { if ($result_set[0]->display_name == $comment_author){ fail('博主你也敢冒充?'); } else { fail('博主你也敢冒充?'); } }}$comment_id = wp_new_comment( $commentdata );$comment = get_comment($comment_id); if( !$user->ID ){ setcookie('comment_author_' . COOKIEHASH, $comment->comment_author, time() + 30000000, COOKIEPATH, COOKIE_DOMAIN); setcookie('comment_author_email_' . COOKIEHASH, $comment->comment_author_email, time() + 30000000, COOKIEPATH, COOKIE_DOMAIN); setcookie('comment_author_url_' . COOKIEHASH, clean_url($comment->comment_author_url), time() + 30000000, COOKIEPATH, COOKIE_DOMAIN);}@header('Content-type: ' . get_option('html_type') . '; charset=' . get_option('blog_charset')); xz_comment($comment, null);//這是我的調用評論函數,換成你的函數名。 die();}}add_action('init', 'ajax_comment');

Javascript 中代碼
注意:以下代碼需要 Jquery 框架支援。
javascript onload 代碼中加入以下部分。

if (jQuery('#commentform').length) {  jQuery('#commentform').submit(function(){  // 截獲提交動作//ID為 commentform 的表單提交時發生的函數,也就是整個留言輸入框 form 的ID。 var ajaxCommentsURL = window.location.href;    jQuery.ajax({      url: ajaxCommentsURL,      data: jQuery('#commentform').serialize()+'&action=ajax_comment',        type: 'POST',      beforeSend: function() {        jQuery('#commenterror').hide();        jQuery('#commentload').fadeIn();      },      error: function(request) {  //發生錯誤時        jQuery('#commenterror').html(request.responseText);        jQuery('#commentload').hide();  //隱藏 submit        jQuery('#commenterror').fadeIn(); //顯示 error       },      success: function(data) {        jQuery('textarea').each(function(){          this.value='';        });        jQuery('#commenterror').fadeOut();        if(jQuery(".commentlist li.comment").first().length != 0){jQuery(".commentlist li.comment").first().before(data)}          else {jQuery("ol.commentlist").append(data)}        jQuery(".commentlist li.comment").first().hide(0,function(){$(this).slideDown(1000)});        jQuery('#cmt-submit').attr('disabled', true).css({"background-color":"#6C6C6C","color":"#E0E0E0"});        jQuery('#commentload').fadeOut(1600); setTimeout(function() {        jQuery('#cmt-submit').removeAttr('disabled').css({"background-color":"#0086C5","color":"#FFFFFF"});        },3000);       }    });    return false;  } );}

注:代碼仍有改進需求,因為沒有時間,所以就沒有再進化。

CSS 代碼
css 隨意部分添加。

#commentload,#commenterror{ display: none; margin: 5px 0 0 0; color:#D29A04; float: left; font-size:16px; padding:0 0 0 20px;}#commentload{ background: url("img/loading.gif") no-repeat bottom left ;}#commenterror{ background: url("img/error.png") no-repeat bottom left ;}

原理、思路
原理:
Javascript 提交數據
php響應并輸出結果
Javascript 得到結果并顯示
思路:
點擊提交按鈕后,Javascript 截獲提交動作
截獲提交的各項數據(Name、Email、Web、Comment-text)
利用 Javascript Jquery 模擬瀏覽器提交POST(Name、Email、Web、Comment-text)請求之WordPress
Function.php 文件中構造一個接受請求的函數,即本列中ajax_comment函數
如果請求無錯誤,輸出正確結果
如果請求有錯誤,輸出錯誤結果
Javascript 獲得正確結果,動態添加到評論列表中
Javascript 獲得錯誤結果,動態添加到提交提示欄
改進
樣式方面,我確實沒什么美感,所以正在學習中。
提交按鈕在點擊至獲得返回結果后3秒的時間里應該都是變灰失效狀態,這一點之前因為在本機測試,提交瞬間完成沒有注意到,遠程測試的時候發現了,但要改的話還要進行測試,時間太緊就不改了,有機會再改進一下。

總結
因為 WordPress 主題中評論樣式的自由性、多樣性,所以貌似至今一直沒有一款通用性的AJAX 評論插件,
一些高手也只能在優化自己博客之余,把思路和部分通用核心代碼做一下公布,
所以想要實現一些炫酷的功能要不有高人幫你,
要不你就只能好好學代碼,期待有一日能夠厚積薄發了。
效果請自行提交評論驗證。



注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产一区二区在线免费| 国产视频久久久久| 国产成人在线视频| 91九色蝌蚪国产| 久久久久久久色| 亚洲天堂影视av| 国产成人拍精品视频午夜网站| 欧洲日本亚洲国产区| 国产精品18久久久久久麻辣| 亚洲片国产一区一级在线观看| 亚洲精品美女在线观看播放| 日韩国产在线播放| 在线观看精品自拍私拍| 九九九久久国产免费| 亚洲娇小xxxx欧美娇小| 国内精品久久久久久中文字幕| 欧美最顶级的aⅴ艳星| 国产97色在线| 国产精品嫩草影院一区二区| 国外成人在线直播| 国外成人免费在线播放| 精品久久久久久久久中文字幕| 亚洲天堂开心观看| 亲爱的老师9免费观看全集电视剧| 久久精品国产v日韩v亚洲| 动漫精品一区二区| 亚洲精品成人网| 成人中心免费视频| 国产精品69精品一区二区三区| 久久综合国产精品台湾中文娱乐网| 欧美大肥婆大肥bbbbb| 日韩美女中文字幕| 成人黄在线观看| 亚洲国产成人在线视频| 欧美日韩激情美女| 国产一区二区三区直播精品电影| 欧美精品在线免费播放| 日韩精品极品在线观看播放免费视频| 国产精品丝袜久久久久久高清| 欧美色图在线视频| 日韩视频中文字幕| 欧美亚州一区二区三区| 欧美综合在线观看| 成人精品福利视频| 国产福利精品视频| 国产欧美日韩中文字幕| 国外色69视频在线观看| 91夜夜揉人人捏人人添红杏| 久久手机精品视频| 亚洲三级黄色在线观看| 国产丝袜精品第一页| 96pao国产成视频永久免费| 久久综合免费视频| 日韩电影免费观看在线| 久久久精品国产亚洲| 亚洲成色777777在线观看影院| 亚洲欧美日韩国产中文| 69久久夜色精品国产7777| 丝袜情趣国产精品| 最近更新的2019中文字幕| 国产男人精品视频| 中文字幕免费国产精品| 中文字幕亚洲综合| 国产精品一区电影| 日韩精品亚洲元码| 亚洲国产小视频在线观看| 欧美精品在线免费观看| 亚洲伊人久久大香线蕉av| 九九热在线精品视频| 久久久久99精品久久久久| 亚洲电影在线看| 国产精品视频在线观看| 91精品国产自产在线观看永久| 91精品视频一区| 91成人天堂久久成人| 亚洲国产成人爱av在线播放| 4388成人网| 久久成人av网站| 91经典在线视频| 亚洲日本成人女熟在线观看| 欧美最猛性xxxxx(亚洲精品)| 91精品国产综合久久久久久蜜臀| 欧美二区乱c黑人| 精品国产91久久久久久老师| 欧美国产精品va在线观看| 亚洲肉体裸体xxxx137| 中文字幕久精品免费视频| 高清欧美性猛交xxxx黑人猛交| 人妖精品videosex性欧美| 一道本无吗dⅴd在线播放一区| 亚洲欧美另类国产| 日韩欧美精品中文字幕| 欧美亚洲免费电影| 欧美视频免费在线观看| 成人久久一区二区三区| 亚洲最新av网址| 91免费在线视频| 日韩成人高清在线| 亚洲国产另类 国产精品国产免费| 国产精品一区二区久久久久| 国产精品美腿一区在线看| 91精品久久久久久久| 亚洲嫩模很污视频| 精品视频久久久久久| 国产精品999| 亚洲视频999| 好吊成人免视频| 欧美一区第一页| 国产在线视频91| 国模视频一区二区三区| 狠狠躁夜夜躁人人躁婷婷91| 欧美精品中文字幕一区| 精品无码久久久久久国产| 久久91精品国产| 草民午夜欧美限制a级福利片| 性欧美亚洲xxxx乳在线观看| 亚洲精品欧美极品| 日韩在线小视频| 国产z一区二区三区| www.99久久热国产日韩欧美.com| 国产成人亚洲综合91| 国产91精品黑色丝袜高跟鞋| 亚洲剧情一区二区| 国产精品久久电影观看| 精品国产电影一区| 国产欧美亚洲视频| 国产男女猛烈无遮挡91| 中文字幕欧美精品日韩中文字幕| 国产精品日韩欧美| 国产欧美久久久久久| 欧美裸体xxxxx| 国产日韩欧美另类| 北条麻妃一区二区在线观看| 久久综合九色九九| 国产精国产精品| 日韩电影中文字幕在线| 国产精品91在线观看| 色婷婷**av毛片一区| 91精品国产99久久久久久| 性欧美视频videos6一9| 国产精品亚洲欧美导航| 国产美女精彩久久| 九九热这里只有精品6| 欧美日韩久久久久| 美女av一区二区| 国产成人精品综合久久久| 91香蕉嫩草神马影院在线观看| 色综合伊人色综合网站| 91精品国产综合久久久久久蜜臀| 日韩中文av在线| 欧美日韩人人澡狠狠躁视频| 亚洲专区中文字幕| 久久久久亚洲精品国产| 亚洲精品福利免费在线观看| 日韩网站免费观看| 久久久久久久av| 久热精品视频在线免费观看| 日韩电影中文字幕av| 成人免费xxxxx在线观看| 69av成年福利视频| 中文字幕欧美亚洲| 欧美国产日韩中文字幕在线| 不卡av在线播放| 国产日韩综合一区二区性色av|