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

首頁 > 網站 > 建站經驗 > 正文

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

2024-04-25 20:43:56
字體:
來源:轉載
供稿:網友

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

直接開門見山,直接上代碼:(原理及思路在最后)

根據自己主題不同結構,以下代碼請自行調整。

WordPress Ajax 提交評論 PHP 代碼

在主題 function.php 文件中加入如下部分。

//以下大部分代碼出自 yinheli 經由該部分代碼,排除部分錯誤、優化精簡得出以下代碼。

//yinheli博客不做了,所以這里就不給鏈接了。

//Edited by XiangZi DEC.17TH 2011

function 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 評論插件,

一些高手也只能在優化自己博客之余,把思路和部分通用核心代碼做一下公布,

所以想要實現一些炫酷的功能要不有高人幫你,

要不你就只能好好學代碼,期待有一日能夠厚積薄發了。

效果請自行提交評論驗證。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情综合亚洲一二区| 欧美成人在线免费视频| 亚洲毛片在线观看.| 日韩欧美国产成人| 久久国产精品影片| 久久琪琪电影院| 久久精品人人爽| 亚洲女人被黑人巨大进入al| 97视频免费在线观看| 亚洲aⅴ日韩av电影在线观看| 日韩成人激情视频| 亚洲精品久久久久久下一站| 欧美成人剧情片在线观看| 日韩一区av在线| 成人激情视频在线| 92国产精品久久久久首页| 最新69国产成人精品视频免费| 久久精品国产亚洲7777| 亚洲欧洲在线免费| 欧美夫妻性生活xx| www.xxxx欧美| 国产精品精品视频一区二区三区| 日韩欧美在线第一页| 国产欧美婷婷中文| 日韩欧美在线免费| 亚洲精品av在线| 日本精品性网站在线观看| 日韩中文在线中文网在线观看| 日韩极品精品视频免费观看| 中文字幕欧美国内| 欧美日韩福利电影| 亚洲欧美中文字幕| 91夜夜未满十八勿入爽爽影院| 日韩中文字幕免费视频| 国产精品18久久久久久麻辣| 日韩欧美极品在线观看| 自拍偷拍亚洲区| 欧美性xxxxx极品娇小| 97视频在线观看亚洲| 夜夜狂射影院欧美极品| 国产精品你懂得| 国产精品福利网| 宅男66日本亚洲欧美视频| 97超视频免费观看| 久久久噜久噜久久综合| 国产女人精品视频| 欧美一级淫片丝袜脚交| 91国在线精品国内播放| 中文字幕九色91在线| 国产精品jizz在线观看麻豆| 性金发美女69hd大尺寸| 欧美日韩在线视频一区二区| 亚洲伊人久久综合| 精品欧美aⅴ在线网站| 91美女片黄在线观看游戏| 日韩视频在线观看免费| 日韩电影中文字幕一区| 亚洲精品国产suv| 激情亚洲一区二区三区四区| 国产91精品青草社区| 日韩欧美亚洲范冰冰与中字| 亚洲欧美在线免费观看| 精品国产成人av| 亚洲欧美日韩爽爽影院| 亚洲欧美中文另类| 午夜精品久久久久久久久久久久久| 在线观看精品国产视频| 色综合久久精品亚洲国产| 45www国产精品网站| 国产激情999| 日韩av在线不卡| 亚洲欧美日韩精品久久奇米色影视| 欧美激情免费在线| 亚洲一区二区免费在线| 欧美高清在线视频观看不卡| 色悠悠久久88| 日本精品一区二区三区在线播放视频| 久久精品国产久精国产思思| 国产精品久久久久7777婷婷| 国产午夜一区二区| 国产福利成人在线| 青青草原成人在线视频| 国产精品视频免费在线观看| 亚洲一区二区三区四区在线播放| 国产精品∨欧美精品v日韩精品| 国产精品一区二区三区免费视频| 亚洲国产古装精品网站| 国产精品96久久久久久又黄又硬| 92版电视剧仙鹤神针在线观看| 国产成人久久精品| 欧美专区中文字幕| 国产精品狼人色视频一区| 欧美性受xxxx白人性爽| 国产欧美最新羞羞视频在线观看| 97香蕉超级碰碰久久免费软件| 欧美xxxx18国产| 色综合天天狠天天透天天伊人| 久久久精品久久| 亚洲视频在线免费看| 92国产精品久久久久首页| 午夜精品久久久久久久久久久久| 国产美女扒开尿口久久久| 国产日韩在线免费| 亚洲久久久久久久久久久| 亚洲国产精久久久久久| 国产精品福利久久久| 色诱女教师一区二区三区| 中文字幕精品一区久久久久| 欧美亚洲午夜视频在线观看| 欧美性猛交99久久久久99按摩| 亚洲精品久久久久中文字幕欢迎你| 日本欧美在线视频| 欧美午夜性色大片在线观看| zzjj国产精品一区二区| 亚洲美女在线观看| 91亚洲国产成人精品性色| 国产精品久久久久99| 欧美中文在线观看| 国产欧美久久久久久| 国产精品久久久久久久久久东京| 欧美理论电影网| 亚洲日本欧美日韩高观看| 日韩欧美在线观看| 麻豆国产精品va在线观看不卡| 国产一区二区三区视频免费| 欧美色道久久88综合亚洲精品| 中文字幕久久久| 韩国欧美亚洲国产| 国产成人精品视频在线观看| 国产精品视频一区二区高潮| 久久久久国产精品www| 日韩精品亚洲视频| 国产欧美一区二区三区在线| 欧美黄色小视频| 亚洲aaa激情| 国产日韩综合一区二区性色av| 亚洲最大成人网色| 成人精品一区二区三区| 欧美老肥婆性猛交视频| 国产成人精品日本亚洲| 亚洲一级片在线看| 热久久这里只有| 日韩精品免费在线视频观看| 麻豆成人在线看| 日韩中文字幕不卡视频| 成人av.网址在线网站| 久久九九全国免费精品观看| 中文精品99久久国产香蕉| 精品福利视频导航| 91在线色戒在线| 97在线观看免费高清| 91精品视频在线播放| 亚洲黄页网在线观看| 日韩av最新在线| 亚洲欧美国产精品| 国产精品久久久久7777婷婷| 日韩亚洲欧美中文高清在线| 成人一区二区电影| 狠狠综合久久av一区二区小说| 欧美精品18videos性欧| 亚洲成av人乱码色午夜| 国产精品激情av在线播放| 亚洲天堂男人天堂女人天堂| 欧美亚洲成人网|