上一篇文章,我們在 WordPress 後臺文章編輯頁面新增了自定義面板,並且在自定義面板中可以輸入關鍵詞和描述資訊,但是我們僅僅使用了一個 textarea 文字域表單,這在實際應用中是遠遠不夠的,實際應用我們可能需要文字框、文字域、單選框、核取方塊、下拉選擇框、圖片上傳、甚至是 WordPress 自帶的文字編輯器或者自己配置的文字編輯器以及各種帶 js 特效的應用。

今天我們給自定義面板新增簡單的表單:文字框、文字域、單選框、核取方塊、下拉選擇框。

我們繼續使用昨天的檔案,改進昨天的程式碼。

首先準備工作:

先將昨天新建的 metabox.php 檔案中的程式碼清楚,準備欄位陣列:我們可以參考前面後臺教程中配置選項陣列的方法來配置資料項:設定選項類檔案使用方法:

  1. $new_meta_boxes =    
  2. array(   
  3.     "title" => array(   
  4.         "name" => "_meta_title",   
  5.         "std" => "",   
  6.         "title" => "標題",   
  7.         "type"=>"title"),      
  8.      
  9.     "keywords" => array(   
  10.         "name" => "_meta_keywords",   
  11.         "std" => "",      
  12.         "title" => "關鍵字",   
  13.         "type"=>"text"),   
  14.            
  15.     "description" => array(   
  16.         "name" => "_meta_description",   
  17.         "std" => "",      
  18.         "title" => "描述",   
  19.         "type"=>"textarea"),   
  20.            
  21.     "category" => array(   
  22.         "name" => "_meta_cate",   
  23.         "std" => "",      
  24.         "title" => "選擇分類",   
  25.         "subtype"=> "cat",   
  26.         "type"=>"dropdown"),   
  27.            
  28.     "radio" => array(   
  29.         "name" => "_meta_radio",   
  30.         "std" => 1,      
  31.         "title" => "單選框",   
  32.         "buttons" => array('Yes','No'),   
  33.         "type"=>"radio"),   
  34.            
  35.     "checkbox" => array(   
  36.         "name" => "_meta_checkbox",   
  37.         "std" => 1,      
  38.         "title" => "核取方塊",   
  39.         "type"=>"checkbox"),   
  40.            
  41. );  

二、建立 (顯示) 面板內容的函式

  1. function new_meta_boxes() {   
  2.     global $post$new_meta_boxes;   
  3.     foreach($new_meta_boxes as $meta_box) {   
  4.         //獲取儲存的是   
  5.         $meta_box_value = get_post_meta($post->ID, $meta_box['name'].'_value', true);   
  6.         if($meta_box_value != "")      
  7.             $meta_box['std'] = $meta_box_value;//將預設值替換為以儲存的值   
  8.            
  9.         echo'<input type="hidden" name="'.$meta_box['name'].'_noncename" id="'.$meta_box['name'].'_noncename" value="'.wp_create_nonce( plugin_basename(__FILE__) ).'" />';   
  10.         //透過選擇型別輸出不同的 html 程式碼   
  11.         switch ( $meta_box['type'] ){   
  12.             case 'title':   
  13.                 echo'<h4>'.$meta_box['title'].'</h4>';   
  14.                 break;   
  15.             case 'text':   
  16.                 echo'<h4>'.$meta_box['title'].'</h4>';   
  17.                 echo '<input type="text" size="40" name="'.$meta_box['name'].'_value" value="'.$meta_box['std'].'" /><br />';   
  18.                 break;   
  19.             case 'textarea':   
  20.                 echo'<h4>'.$meta_box['title'].'</h4>';   
  21.                 echo '<textarea cols="60" rows="3" name="'.$meta_box['name'].'_value">'.$meta_box['std'].'</textarea><br />';   
  22.                 break;   
  23.             case 'dropdown':   
  24.                 echo'<h4>'.$meta_box['title'].'</h4>';   
  25.                 if($meta_box['subtype'] == 'cat'){   
  26.                     $select = 'Select category';   
  27.                     $entries = get_categories('title_li=&orderby=name&hide_empty=0');//獲取分類   
  28.                 }   
  29.                 echo '<p><select name="'.$meta_box['name'].'_value"> ';   
  30.                 echo '<option value="">'.$select .'</option>  ';   
  31.                 foreach ($entries as $key => $entry){   
  32.                     $id = $entry->term_id;   
  33.                     $title = $entry->name;   
  34.                     if ( $meta_box['std'] == $id ){   
  35.                         $selected = "selected='selected'";   
  36.                     }else{   
  37.                         $selected = "";   
  38.                     }   
  39.                     echo "<option $selected value='"$id."'>"$title."</option>";   
  40.                 }   
  41.                 echo '</select><br />';   
  42.                 break;   
  43.             case 'radio':   
  44.                 echo'<h4>'.$meta_box['title'].'</h4>';   
  45.                 $counter = 1;   
  46.                 foreach$meta_box['buttons'] as $radiobutton ) {   
  47.                     $checked ="";   
  48.                     if(isset($meta_box['std']) && $meta_box['std'] == $counter) {   
  49.                         $checked = 'checked = "checked"';   
  50.                     }   
  51.                     echo '<input '.$checked.' type="radio" class="kcheck" value="'.$counter.'" name="'.$meta_box['name'].'_value"/>'.$radiobutton;   
  52.                     $counter++;   
  53.                 }   
  54.                 break;   
  55.             case 'checkbox':   
  56.                 echo'<h4>'.$meta_box['title'].'</h4>';   
  57.                 if( isset($meta_box['std']) && $meta_box['std'] == 'true' )   
  58.                     $checked = 'checked = "checked"';   
  59.                 else  
  60.                     $checked  = '';    
  61.                 echo '<input type="checkbox" name="'.$meta_box['name'].'_value" value="true"  '.$checked.' />';   
  62.             break;   
  63.                
  64.         }             
  65.     }      
  66. }  

三、建立面板

  1. function create_meta_box() {      
  2.     global $theme_name;      
  3.      
  4.     if ( function_exists('add_meta_box') ) {      
  5.         add_meta_box( 'new-meta-boxes', '自定義模組', 'new_meta_boxes', 'post', 'normal', 'high' );      
  6.     }      
  7. }  

四、儲存更新資料

  1. function save_postdata( $post_id ) {      
  2.     global $post$new_meta_boxes;      
  3.      
  4.     foreach($new_meta_boxes as $meta_box) {      
  5.         if ( !wp_verify_nonce( $_POST[$meta_box['name'].'_noncename'], plugin_basename(__FILE__) ))  {      
  6.             return $post_id;      
  7.         }      
  8.      
  9.         if ( 'page' == $_POST['post_type'] ) {      
  10.             if ( !current_user_can( 'edit_page', $post_id ))      
  11.                 return $post_id;      
  12.         }       
  13.         else {      
  14.             if ( !current_user_can( 'edit_post', $post_id ))      
  15.                 return $post_id;      
  16.         }      
  17.      
  18.         $data = $_POST[$meta_box['name'].'_value'];      
  19.      
  20.         if(get_post_meta($post_id$meta_box['name'].'_value') == "")      
  21.             add_post_meta($post_id$meta_box['name'].'_value', $data, true);      
  22.         elseif($data != get_post_meta($post_id$meta_box['name'].'_value', true))      
  23.             update_post_meta($post_id$meta_box['name'].'_value', $data);      
  24.         elseif($data == "")      
  25.             delete_post_meta($post_id$meta_box['name'].'_value', get_post_meta($post_id$meta_box['name'].'_value', true));      
  26.     }      
  27. }  

 五、觸發函式

  1. add_action('admin_menu', 'create_meta_box');      
  2. add_action('save_post', 'save_postdata');   

效果:

呼叫的時候使用 get_post_meta 函式獲取即可,不過主要我們儲存的欄位名稱,雖然我們的配置陣列中配置了 name,但是儲存自定義欄位的時候我們在欄位名稱後面加了_value,以我們的關鍵字_meta_keywords 為例,獲取應該是:

  1. $ashu_eitor = get_post_meta($post->ID, "_meta_keywords_value", true);  

 

其實本教程的程式碼很多和前面的相同,只不過給準備的資料加了個型別判斷,透過判斷型別來輸出不同的 html 程式碼。。