麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > CMS > Wordpress > 正文

WordPress Ajax 提交評論的實現思路與方法

2024-09-07 00:51:05
字體:
來源:轉載
供稿:網友

直對 WordPress 的 Ajax 交互研究感興趣,也一直很關注于這方面的技術,談到 WordPress Ajax就不得不談到評論 Ajax提交,作為一個博客、論壇評論的 Ajax 提交不僅可以改善用戶體驗,還可以大幅縮減服務器開支,畢竟輸出單條評論內容比重新組織輸出一個頁面要簡單的多.

雖說現在訪問量一直比較低,不存在服務器壓力的問題,但一向注重用戶體驗的我,當然不能放棄這么一個提升用戶體驗的機會,今天抽了一下午的空,把這個主題的 Ajax 評論提交初步完成了.

根據自己主題不同結構,以下代碼請自行調整,WordPress Ajax 提交評論 PHP 代碼,在主題 function.php 文件中加入如下部分:

  1. //以下大部分代碼出自 yinheli 經由該部分代碼,排除部分錯誤、優化精簡得出以下代碼。 
  2. //yinheli博客不做了,所以這里就不給鏈接了。 
  3. //Edited by XiangZi DEC.17TH 2011 
  4. function fail($s) {//虛擬錯誤頭部分 
  5.     header('HTTP/1.0 500 Internal Server Error'); 
  6.     echo $s
  7.     exit
  8. function ajax_post_comment_slow (){ 
  9.  fail('用不用說這么快?想好了再說!'); 
  10. //評論太快輸出代碼。 
  11. add_filter('comment_flood_trigger','ajax_post_comment_slow', 0); 
  12. //掛一個評論太快,返回內容的鉤子 
  13. function ajax_comment(){ 
  14. // Ajax php 響應部分代碼 
  15. if($_POST['action'] == 'ajax_comment') { 
  16.     global $wpdb$db_check
  17.         // Check DB 
  18.         if(!$wpdb->dbh) { 
  19.             echo('Our database has issues. Try again later.'); 
  20.    die(); 
  21.         }  
  22. nocache_headers(); 
  23. $comment_post_ID = (int) $_POST['comment_post_ID']; 
  24.  $status = $wpdb->get_row("SELECT post_status, comment_status FROM $wpdb->posts WHERE ID = '$comment_post_ID'"); 
  25. if ( emptyempty($status->comment_status) ) { 
  26. //這一套判斷貌似抄的 wp 源代碼 。詳見:include/comment.php 
  27.     do_action('comment_id_not_found'$comment_post_ID); 
  28.     fail('The post you are trying to comment on does not currently exist in the database.'); 
  29. elseif ( 'closed' ==  $status->comment_status ) { 
  30.     do_action('comment_closed'$comment_post_ID);; 
  31.     fail('Sorry, comments are closed for this item.'); 
  32. elseif ( in_array($status->post_status, array('draft''pending') ) ) { 
  33.     do_action('comment_on_draft'$comment_post_ID); 
  34.     fail('The post you are trying to comment on has not been published.'); 
  35. $comment_author       = trim(strip_tags($_POST['author'])); 
  36. $comment_author_email = trim($_POST['email']); 
  37. $comment_author_url   = trim($_POST['url']); 
  38. $comment_content      = trim($_POST['comment']); 
  39. // If the user is logged in 
  40. $user = wp_get_current_user(); 
  41. if ( $user->ID ) { 
  42.     $comment_author       = $wpdb->escape($user->display_name); 
  43.     $comment_author_email = $wpdb->escape($user->user_email); 
  44.     $comment_author_url   = $wpdb->escape($user->user_url); 
  45.     if ( current_user_can('unfiltered_html') ) { 
  46.         if ( wp_create_nonce('unfiltered-html-comment_' . $comment_post_ID) != $_POST['_wp_unfiltered_html_comment'] ) { 
  47.             kses_remove_filters(); // start with a clean slate 
  48.             kses_init_filters(); // set up the filters 
  49.         } 
  50.     } 
  51. else { 
  52.     if ( get_option('comment_registration') ) 
  53.         fail('火星人?注冊個?'); 
  54. $comment_type = ''
  55. if ( get_option('require_name_email') && !$user->ID ) { 
  56.     if ( 6> strlen($comment_author_email) || '' == $comment_author ) 
  57.         fail('Oopps,名字[Name]或郵箱[email]不對。'); 
  58.     elseif ( !is_email($comment_author_email)) 
  59.         fail('Oopps,郵箱地址[Email]不對。'); 
  60. if ( '' == $comment_content ) 
  61.     fail('是不是應該寫點什么再提交?'); 
  62. // Simple duplicate check 
  63. $dupe = "SELECT comment_ID FROM $wpdb->comments WHERE comment_post_ID = '$comment_post_ID' AND ( comment_author = '$comment_author' "
  64. if ( $comment_author_email ) $dupe .= "OR comment_author_email = '$comment_author_email' "
  65. $dupe .= ") AND comment_content = '$comment_content' LIMIT 1"
  66. if ( $wpdb->get_var($dupe) ) { 
  67.     fail('評論重復了!有木有!'); 
  68. $commentdata = compact('comment_post_ID''comment_author''comment_author_email''comment_author_url''comment_content''comment_type''user_ID'); 
  69. if( !$user->ID ){ 
  70.  $result_set = $wpdb->get_results("SELECT display_name, user_email FROM $wpdb->users WHERE display_name = '" . $comment_author . "' OR user_email = '" . $comment_author_email . "'"); 
  71.  if ($r(www.111cn.net)esult_set) { 
  72.  if ($result_set[0]->display_name == $comment_author){ 
  73.  fail('博主你也敢冒充?'); 
  74.  } else { 
  75.  fail('博主你也敢冒充?'); 
  76.  } 
  77.  } 
  78. $comment_id = wp_new_comment( $commentdata ); 
  79. $comment = get_comment($comment_id); 
  80.  
  81. if( !$user->ID ){ 
  82.  setcookie('comment_author_' . COOKIEHASH, $comment->comment_author, time() + 30000000, COOKIEPATH, COOKIE_DOMAIN); 
  83.  setcookie('comment_author_email_' . COOKIEHASH, $comment->comment_author_email, time() + 30000000, COOKIEPATH, COOKIE_DOMAIN); 
  84.  setcookie('comment_author_url_' . COOKIEHASH, clean_url($comment->comment_author_url), time() + 30000000, COOKIEPATH, COOKIE_DOMAIN); 
  85. @header('Content-type: ' . get_option('html_type') . '; charset=' . get_option('blog_charset')); 
  86.  xz_comment($comment, null);//這是我的調用評論函數,換成你的函數名。 
  87.  die(); 
  88. add_action('init''ajax_comment'); 

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

  1. if (jQuery('#commentform').length) { 
  2.     jQuery('#commentform').submit(function(){     
  3. // 截獲提交動作 
  4. //ID為 commentform 的表單提交時發生的函數,也就是整個留言輸入框 form 的ID。 
  5.   var ajaxCommentsURL = window.location.href; 
  6.         jQuery.ajax({ 
  7.             url: ajaxCommentsURL, 
  8.             data: jQuery('#commentform').serialize()+'&action=ajax_comment',     
  9.             type: 'POST'
  10.             beforeSend: function() { 
  11.                 jQuery('#commenterror').hide(); 
  12.                 jQuery('#commentload').fadeIn(); 
  13.             }, 
  14.             error: function(request) {    //發生錯誤時 
  15.                 jQuery('#commenterror').html(request.responseText); 
  16.                 jQuery('#commentload').hide();    //隱藏  submit 
  17.                 jQuery('#commenterror').fadeIn(); //顯示 error  
  18.             }, 
  19.             success: function(data) { 
  20.                 jQuery('textarea').each(function(){ 
  21.                     this.value=''
  22.                 }); 
  23.                 jQuery('#commenterror').fadeOut(); 
  24.                 if(jQuery(".commentlist li.comment").first().length != 0){jQuery(".commentlist li.comment").first().before(data)}    
  25.                 else {jQuery("ol.commentlist").append(data)} 
  26.                 jQuery(".commentlist li.comment").first().hide(0,function(){$(this).slideDown(1000)}); 
  27.                 jQuery('#cmt-submit').attr('disabled'true).css({"background-color":"#6C6C6C","color":"#E0E0E0"}); 
  28.                 jQuery('#commentload').fadeOut(1600); 
  29.   setTimeout(function() { 
  30.                 jQuery('#cmt-submit').removeAttr('disabled').css({"background-color":"#0086C5","color":"#FFFFFF"}); 
  31.                 },3000);  
  32.             } 
  33.         }); 
  34.        return false
  35.    } ); 

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

CSS 代碼,css 隨意部分添加:

  1. #commentload,#commenterror{ 
  2.  displaynone
  3.  margin5px 0 0 0
  4.  color:#D29A04
  5.  floatleft
  6.  font-size:16px
  7.  padding:0 0 0 20px
  8. #commentload{ 
  9.  backgroundurl("img/loading.gif"no-repeat bottom left ; 
  10. #commenterror{ 
  11.  backgroundurl("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 評論插件,一些高手也只能在優化自己博客之余,把思路和部分通用核心代碼做一下公布,所以想要實現一些炫酷的功能要不有高人幫你,要不你就只能好好學代碼,期待有一日能夠厚積薄發了,效果請自行提交評論驗證.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 2021国产精品视频 | 国产色爱综合网 | 91av原创| 日日鲁夜夜视频热线播放 | 久久99综合久久爱伊人 | 一级成人黄色片 | 得得啪在线视频 | 国产精品久久久久久久久久东京 | 91精品久久香蕉国产线看观看 | 嫩草91在线 | 欧美性生交zzzzzxxxxx | 中文字幕11| 成人午夜小视频 | 中文字幕亚洲情99在线 | 欧美18—19sex性hd按摩 | 涩涩天堂 | 欧日韩在线 | 国产在线精品91 | 成人毛片免费 | 久久久久久久久久91 | 久草手机在线 | 国产亚洲高清在线精品不卡 | 亚洲第一成人av | 中文字幕亚洲一区二区三区 | 羞羞视频免费网站 | 免费黄色大片网站 | 一本一本久久a久久精品综合小说 | 一级毛片手机在线观看 | www.精品一区| 亚洲5区 | 91伊人久久 | 国产精品嘿咻嘿咻在线播放 | 亚洲精品a在线观看 | 免费观看一区 | 91看片免费版 | 国产精品一区二区羞羞答答 | 日本在线播放一区二区 | 羞羞电影网 | 九九热在线免费观看视频 | 亚洲一区免费观看 | 亚州精品国产 |