本篇教程要實現的內容為文章定踩功能,或者說 「喜歡」「不喜歡」 。
應用例項:

實現步驟:
本例項以上圖所示喜歡和不喜歡為例。
一、新建資料表
新建資料表,將文章投票資料儲存在新的資料表中,我們需要記錄使用者 ID,文章 ID,投票內容,使用者 ip,新資料表如下:

實現新建資料表程式碼如下,將程式碼新增進主題的 functions.php(或自定) 檔案中:
- /*********更新重寫規則***************/
- function ashu_load_theme() {
- global $pagenow;
- if ( is_admin() && 'themes.php' == $pagenow && isset( $_GET['activated'] ) )
- ashu_vote_install(); //啟用主題的時候執行函式
- }
- add_action( 'load-themes.php', 'ashu_load_theme' );
- function ashu_vote_install(){
- global $wpdb;
- //建立 _post_vote 表
- $table_name = $wpdb->prefix . 'post_vote';
- if( $wpdb->get_var("SHOW TABLES LIKE '$table_name'") != $table_name ) :
- $sql = " CREATE TABLE `".$wpdb->prefix."post_vote` (
- `id` BIGINT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
- `user` INT NOT NULL ,
- `post` INT NOT NULL ,
- `rating` varchar(10),
- `ip` varchar(40)
- ) ENGINE = MYISAM DEFAULT CHARSET=utf8;";
- require_once(ABSPATH . 'wp-admin/includes/upgrade.php');
- dbDelta($sql);
- endif;
- }
二、準備投票和查詢函式
準備資料庫操作函式,包括新增資料函式和查詢資料,將如下函式程式碼也新增到主題的 functions.php 檔案 (或自定):
1 、新增資料函式
- /*
- *新增投票函式
- *$post_id 文章 id
- *$user_id 使用者 ID
- *$ip 使用者 IP
- *$rating 投票內容
- */
- function add_vote($post_id,$user_id='',$ip='',$rating='up'){
- global $wpdb;
- $user_id = (int)$user_id;
- $post_id = (int)$post_id;
- if(($user_id=='')&&($ip=='')){
- return "e"; //返回 error
- }
- //檢查使用者對某一文章是否已經投票票了
- if($user_id!=''){
- $check= "select * from ".$wpdb->prefix."post_vote where post='$post_id' and user='$user_id'";
- }else{
- if($ip!=''){
- $check= "select * from ".$wpdb->prefix."post_vote where post='$post_id' and ip='$ip'";
- }
- }
- $coo = $wpdb->get_results($check);
- //投票內容只能是 up 或者 down
- if($rating=='up'){
- $rating='up';
- }else{
- $rating='down';
- }
- //如果不存在資料
- if(!count($coo) > 0){
- //插入資料 sql
- $s = "insert into ".$wpdb->prefix."post_vote (user,post,rating,ip) values('$user_id','$post_id','$rating','$ip')";
- $wpdb->query($s);
- return "y"; //返回 yes
- }else{
- return "h"; //返回 have
- }
- return "e";//返回 error
- }
2 、查詢投票資料函式
比如查詢某文章點選 up 的資料,則使用 get_post_vote(1,'up');
- /*
- *獲取文章投票資料
- *$post_id 文章 ID
- *$vote 投票內容
- */
- function get_post_vote($post_id,$vote='up'){
- global $wpdb;
- $post_id = (int)$post_id;
- if($vote == 'up'){
- $vote='up';
- }else{
- $vote='down';
- }
- //查詢資料 sql
- $sql = "select count(*) from ".$wpdb->prefix."post_vote where post='$post_id' and rating='$vote'";
- $coo = $wpdb->get_var($sql);
- if($coo)
- return $coo; //返回資料
- else
- return 0;
- }
三、準備前臺 html 和 js
建立好了新的資料表,也準備好了實現投票功能的函式,接下來看前臺的 html 和 js 。
1 、網頁前臺顯示資料,將下面的程式碼放在輸出文章的迴圈內,即常說的 loop 中。
- <span class="vote_up" id="<?php echo 'vote_up'.$post->ID;?>">
- <a href="javascript:void(0);" rel="<?php echo 'up_',$post->ID;?>">
- <span id="<?php echo 'vup'.$post->ID;?>">
- <?php echo get_post_vote($post->ID,'up');?>
- </span>
- </a>
- 人認為值得買!</span>
- <span class="vote_down" id="<?php echo 'vote_down'.$post->ID;?>">
- <a href="javascript:void(0);" rel="<?php echo 'down_'.$post->ID;?>">
- <span id="<?php echo 'vdown'.$post->ID;?>">
- <?php echo get_post_vote($post->ID,'down');?>
- </span>
- </a> 人認為不值得買!
- </span>
上面程式碼將會輸出一個如下的 html 結構
- <span class="vote_up" id="vote_up44">
- <a href="javascript:void(0);" title="值得" rel="up_44">
- <span id="vup44">
- 0
- </span>
- </a>
- 人認為值得買!</span>
- <span class="vote_down" id="vote_down44">
- <a href="javascript:void(0);" title="不值" rel="down_44">
- <span id="vdown44">
- 1
- </span>
- </a>人認為不值得買!
- </span>
四、 js 程式碼
本篇教程中和上一篇一樣,我們同樣使用 jquery 發起 ajax 請求,所以首先在網頁頭部載入 jquery 程式碼,我在主題底部檔案 footer.php 中載入 jqeury 。我將 jquery-1.7.2.min.js 放在了主題資料夾的 js 資料夾裡面,所以用 get_template_directory_uri() 函式來輸出主題的 url
- <script src="<?php echo get_template_directory_uri();?>/js/jquery-1.7.2.min.js"></script>
然後我將發起 ajax 請求程式碼也放在了主題裡面 js 資料夾中的 ashu.js 檔案,所以再加上一個
其中輸出了 ajax 請求的地址:www.ashuwp.com/wp-admin/admin-ajax.php
- <script type="text/javascript">var ajax_url = '<?php echo admin_url(); ?>admin-ajax.php';</script>
- <script src="<?php echo get_template_directory_uri();?>/js/ashu.js"></script>
ashu.js 檔案中的程式碼
- /**
- * by ashu.
- * URI: http://www.ashuwp.com
- */
- /**
- * 獲取 Cookie
- *name cookie 名稱
- */
- function getCookie(name) {
- var start = document.cookie.indexOf( name + "=" );
- var len = start + name.length + 1;
- if ( ( !start ) && ( name != document.cookie.substring( 0, name.length ) ) )
- return null;
- if ( start == -1 )
- return null;
- var end = document.cookie.indexOf( ';', len );
- if ( end == -1 )
- end = document.cookie.length;
- return unescape( document.cookie.substring( len, end ) );
- }
- function ashu_isCookieEnable() {
- var today = new Date();
- today.setTime( today.getTime() );
- var expires_date = new Date( today.getTime() + (1000 * 60) );
- document.cookie = 'ashu_cookie_test=test;expires=' + expires_date.toGMTString() + ';path=/';
- var cookieEnable = (getCookie('ashu_cookie_test') == 'test') ? true : false;
- //document.cookie = 'ludou_cookie_test=;expires=Fri, 3 Aug 2001 20:47:11 UTC;path=/';
- return cookieEnable;
- }
- jQuery(document).ready(function($) {
- var ashu_token = 1;
- $('.vote_up a').click(function(){
- //檢查瀏覽器是否啟用 cookie 功能
- if( !ashu_isCookieEnable() ) {
- alert("很抱歉,您不能給本文投票!");
- return;
- }
- if( ashu_token != 1 ) {
- alert("您的滑鼠點得也太快了吧?!");
- return false;
- }
- ashu_token = 0;
- //獲取投票 a 標籤中的 rel 值
- var full_info = $(this).attr( 'rel' );
- var arr_param = full_info.split( '_' ); //以字元"_"分割
- //發起 ajax
- $.ajax({
- url:ajax_url, //ajax 地址
- type:'POST',
- //請求的引數包括 action rating postid 三項
- data:'action=vote_post&rating=' + arr_param[ 0 ] + '&postid=' + arr_param[ 1 ],
- //返回資料
- success:function(results){
- if(results=='n'){
- alert('評價失敗');
- ashu_token = 1;
- }
- if (results=='y'){
- //如果成功,給前臺資料加 1
- var upd_vd = 'vup' + arr_param[ 1 ];
- $('#'+upd_vd).text(parseInt($("#"+upd_vd).text())+1);
- ashu_token = 1;
- }
- if (results=='h'){
- ashu_token = 1;
- alert('已經發表過評價了');
- }
- if (results=='e'){
- ashu_token = 1;
- alert('評價失敗');
- }
- }
- });
- });
- $('.vote_down a').click(function(){
- if( !ashu_isCookieEnable() ) {
- alert("很抱歉,您不能給本文投票!");
- return;
- }
- if(ashu_token != 1) {
- alert("您的滑鼠點得也太快了吧?!");
- return false;
- }
- ashu_token = 0;
- var full_info = $(this).attr( 'rel' );
- var arr_param = full_info.split( '_' );
- $.ajax({
- url:ajax_url,
- type:'POST',
- data:'action=vote_post&rating=' + arr_param[ 0 ] + '&postid=' + arr_param[ 1 ],
- success:function(results){
- if(results=='n'){
- alert('評價失敗');
- ashu_token = 1;
- }
- if (results=='y'){
- var upd_vd = 'vdown' + arr_param[ 1 ];
- $("#"+upd_vd).text(parseInt($("#"+upd_vd).text())+1);
- ashu_token = 1;
- }
- if (results=='h'){
- ashu_token = 1;
- alert('已經發表過評價了');
- }
- if (results=='e'){
- ashu_token = 1;
- alert('發生未知錯誤');
- }
- }
- });
- });
- });
五、後臺 php 處理程式碼。
在前面的教程中,我們的 ajax 請求地址直接是網站頁碼地址,但是本篇教程中,我們的 ajax 請求地址是類似:www.ashuwp.com/wp-admin/admin-ajax.php
使用這個地址來處理 ajax 請求,請一定記得請求中需要有 action 引數,然後我們只需要在 functions.php 檔案 (或自定) 中新增下馬程式碼,即可處理我們的請求,注意執行完請求輸出內容之後,新增 die 函式結束:
- /*
- *wp 的 ajax 都可以透過請求中的 action 引數來執行對應的鉤子
- *示例中我們的 action 引數值是 vote_post
- *所以我們可以直接用下面兩個鉤子來執行動作
- */
- add_action("wp_ajax_vote_post", "add_votes_options");
- add_action("wp_ajax_nopriv_vote_post", "add_votes_options");
- function add_votes_options() {
- if( isset($_POST['action']) && ($_POST['action'] == 'vote_post') ){
- $postid = (int)$_POST['postid'];
- if( !$postid ){
- echo 'e'; //輸出 error
- die(0);
- }
- //cookie 中是否已經存在投票資料
- $voted = $_COOKIE["smzdm_voted_".$postid];
- if( $voted ){
- echo 'h'; //輸出 have
- die(0);
- }
- $ip = $_SERVER['REMOTE_ADDR'];//ip
- $rating = $_POST['rating']; //投票內容
- //判斷使用者是否登入
- if( is_user_logged_in() ){
- global $wpdb, $current_user;
- get_currentuserinfo();
- $uid = $current_user->ID;
- }else{
- $uid='';
- }
- if($rating=='up'){
- $rating='up';
- }else{
- $rating='down';
- }
- //新增資料
- $voted = add_vote($postid,$uid,$ip,$rating);
- if($voted=='y'){
- //設定 cookie
- setcookie("ashu_voted_" . $postid,$rating, time() + 3000000, '/');
- echo 'y';//輸出 yes
- die(0);
- }
- if($voted=='h'){
- //設定 cookie
- setcookie("ashu_voted_" . $postid,$rating, time() + 3000000, '/');
- echo 'h';
- die(0);
- }
- if($voted=='e'){
- echo 'n';//輸出 no
- die(0);
- }
- }else{
- echo 'e';//輸出 eroor
- }
- die(0);
- }
六、結束
本票教程並非實現定踩或喜歡功能的最佳選擇,只是提供一個 ajax 的簡單示例...