国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

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

來源:懂視網 責編:小采 時間:2020-11-27 21:48:44
文檔

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

WordPress中利用AJAX技術進行評論提交的實現示例_javascript技巧:一直對 WordPress 的 Ajax 交互研究感興趣,也一直很關注于這方面的技術,談到 WordPress Ajax 就不得不談到評論 Ajax提交,作為一個博客、論壇評論的 Ajax 提交不僅可以改善用戶體驗,還可以大幅縮減服務器開支,畢竟輸出單條評論內容比重新組織輸出一個頁面
推薦度:
導讀WordPress中利用AJAX技術進行評論提交的實現示例_javascript技巧:一直對 WordPress 的 Ajax 交互研究感興趣,也一直很關注于這方面的技術,談到 WordPress Ajax 就不得不談到評論 Ajax提交,作為一個博客、論壇評論的 Ajax 提交不僅可以改善用戶體驗,還可以大幅縮減服務器開支,畢竟輸出單條評論內容比重新組織輸出一個頁面

一直對 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 代碼中加入以下部分。

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

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 評論插件,
一些高手也只能在優化自己博客之余,把思路和部分通用核心代碼做一下公布,
所以想要實現一些炫酷的功能要不有高人幫你,
要不你就只能好好學代碼,期待有一日能夠厚積薄發了。
效果請自行提交評論驗證。

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

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

WordPress中利用AJAX技術進行評論提交的實現示例_javascript技巧:一直對 WordPress 的 Ajax 交互研究感興趣,也一直很關注于這方面的技術,談到 WordPress Ajax 就不得不談到評論 Ajax提交,作為一個博客、論壇評論的 Ajax 提交不僅可以改善用戶體驗,還可以大幅縮減服務器開支,畢竟輸出單條評論內容比重新組織輸出一個頁面
推薦度:
標簽: 評論 評論的 提交
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 精品久久久久久久中文字幕 | 国产精品电影一区二区 | 国产成人综合精品一区 | 欧洲97色综合成人网 | 欧美 亚洲 中文字幕 | 欧美日韩精品一区二区视频在线观看 | 欧美日本综合 | 日韩电影中文字幕在线网站 | 国产高清在线看 | 欧美成人高清在线视频大全 | 在线观看色视频网站 | 国产精品久久一区二区三区 | 日本美女逼逼 | 国产成人亚洲综合91精品555 | 国产日韩欧美第一页 | 国产在线精品一区二区三区 | 国产网站视频 | 国产精品高清视亚洲一区二区 | 日韩不卡手机视频在线观看 | 九九久久99综合一区二区 | 欧美一区二区在线视频 | 在线亚洲欧美日韩 | 日韩欧美在线综合网高清 | 国产精品国产三级国产a | 久久久久9999| 午夜精品一区二区三区在线视 | 亚洲综合日韩在线亚洲欧美专区 | 在线欧美色图 | 欧美性猛交一区二区三区精品 | 在线精品欧美日韩 | 97热久久免费频精品99国产成人 | 久久九九国产 | 色就是色欧美色图 | 中文字幕在线视频精品 | 一区二区三区免费在线观看 | 欧美日韩黄色大片 | 免费在线观看国产 | 欧美综合国产精品日韩一 | 在线国产视频观看 | 久久久久久久99久久久毒国产 | 国产精品成人久久久 |