WordPress CMS - Возможно ли создавать «динамические» пользовательские типы записей? - PullRequest
1 голос
/ 29 апреля 2011

У меня есть проект WordPress, который будет в основном использоваться в качестве CMS.Благодаря этому замечательному сообществу я перешел от того, что ничего не знал о WordPress, до возможности создавать собственные типы записей (для моего Списка продуктов), классифицировать их с помощью иерархических таксономий и создавать настраиваемые поля для этого Типа записей продуктов.

Теперь мои продукты довольно просты.Они имеют ProductName, ProductType, ProductCategory, DocumentName и DocumentURL.Последние два связаны, потому что DocumentURL - это ссылка на PDF в Интернете, а DocumentName - это метка для DocumentURL.Я создал настраиваемые поля для своих DocumentName и DocumentURL и могу добавить 1 каждое к каждому Product настраиваемому сообщению.Тем не менее, мой Product может иметь МНОГИЕ URL-адреса и имена документов, или он может иметь 1 или даже 0. Есть ли способ сделать его динамичным, чтобы не было значения, сколько у меня?Или мне нужно придумать максимальное число и создать столько настраиваемых полей для настраиваемой публикации продукта?

Если бы это был просто PHP или ASP.NET, я бы просто создал отдельную таблицу БД для документаэлементы и собрать красивую форму с некоторыми jQuery, которые начинаются с 2 или 3 полей документа, и если им нужно больше, они могут щелкнуть символ +, чтобы добавить еще одну строку полей документа (например, http://deepliquid.com/projects/appendo/demos.php). Затем циклчерез них и добавить их в базу данных. Будет ли что-то подобное возможно с WordPress?

Единственная другая идея, которая у меня возникла, - это создание нового пользовательского типа записей для документов и создание отношений с их продуктами, но я могуне зацикливайтесь на том, как это будет работать.

Буду признателен за любой совет! Спасибо!

1 Ответ

4 голосов
/ 29 апреля 2011

Полагаю, вам удобно с PHP, учитывая то, что вы сказали здесь.Хорошей новостью является то, что ваши знания PHP пригодятся здесь.Пришло время изучить новую функцию функции register_post_type;то есть параметр register_meta_box_cb.Это позволяет определить вызываемую функцию для добавления метабокса на страницах cpt add и edit.Например, вот cpt (взятый прямо из кодекса) с добавленным параметром:

add_action('init', 'codex_custom_init');
function codex_custom_init() 
{
  $labels = array(
    'name' => _x('Books', 'post type general name'),
    'singular_name' => _x('Book', 'post type singular name'),
    'add_new' => _x('Add New', 'book'),
    'add_new_item' => __('Add New Book'),
    'edit_item' => __('Edit Book'),
    'new_item' => __('New Book'),
    'view_item' => __('View Book'),
    'search_items' => __('Search Books'),
    'not_found' =>  __('No books found'),
    'not_found_in_trash' => __('No books found in Trash'), 
    'parent_item_colon' => '',
    'menu_name' => 'Books'

  );
  $args = array(
    'labels' => $labels,
    'public' => true,
    'publicly_queryable' => true,
    'show_ui' => true, 
    'show_in_menu' => true, 
    'query_var' => true,
    'rewrite' => true,
    'capability_type' => 'post',
    'has_archive' => true, 
    'hierarchical' => false,
    'menu_position' => null,
    'register_meta_box_cb' => 'my_meta_box_function',
    'supports' => array('title','editor','author','thumbnail','excerpt','comments')
  ); 
  register_post_type('book',$args);
}}

Теперь, когда у вас определена функция cb мета-поля, используйте ее следующим образом:

function my_beta_box_function(){
    add_meta_box(
        'myplugin_sectionid',
        __( 'My Post Section Title', 'myplugin_textdomain' ), 
        'myplugin_inner_custom_box',
        'book'
    );
}

add_meta_box определяет мета-блок для вас и предоставляет функцию, которая создает контент в метабоксе.В этом случае наш код ссылается на функцию myplugin_inner_custom_box.Посмотрите на http://codex.wordpress.org/Function_Reference/add_meta_box для получения дополнительной информации о добавлении мета-блоков.Итак, теперь нам нужно добавить наш контент, определив функцию:

function myplugin_inner_custom_box()
{
   // Everything here would appear in the meta box
}

На этом этапе вы можете использовать свои знания PHP для создания HTML-формы, которую можно обрабатывать при отправке.Вы можете добавить кнопку + и использовать свой PHP так же, как и в любом другом приложении PHP.Я не буду вдаваться в подробности, как это сделать, потому что я предполагаю, что вы можете сделать это.Я на самом деле создал несколько метабоксов, подобных этому, и, узнав о функциях, которые я опубликовал, я мог просто положиться на свои знания PHP.Последний кусок этого - сохранение ввода.Используя функцию, которая определяет вашу подпрограмму сохранения и действие save_post, вы можете использовать свои знания PHP для сохранения данных:

/* Do something with the data entered */
add_action('save_post', 'myplugin_save_postdata');

/* When the post is saved, saves our custom data */
function myplugin_save_postdata( $post_id ) {
  // verify if this is an auto save routine. 
  // If it is our form has not been submitted, so we dont want to do anything
  if ( defined('DOING_AUTOSAVE') && DOING_AUTOSAVE ) 
      return $post_id;

  // verify this came from the our screen and with proper authorization,
  // because save_post can be triggered at other times

  if ( !wp_verify_nonce( $_POST['myplugin_noncename'], plugin_basename(__FILE__) ) )
      return $post_id;


  // Check permissions
  if ( 'page' == $_POST['post_type'] ) 
  {
    if ( !current_user_can( 'edit_page', $post_id ) )
        return $post_id;
  }
  else
  {
    if ( !current_user_can( 'edit_post', $post_id ) )
        return $post_id;
  }

  // OK, we're authenticated: we need to find and save the data

  $mydata = $_POST['myplugin_new_field'];

  update_post_meta('my_field', $mydata);

   return $mydata;
}

Наконец, примечание о функции сохранения.Если вы называете свои поля ввода значением массива (например, docs[]), значение $ _POST ['docs'] будет массивом.К счастью, функция WP * update_post_meta полностью настроена на обработку входов массива.Он будет сериализован и введен.Использование совместимой функции get_post_meta приведет к десериализации массива для использования и подготовки данных.

Удачи!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...