Создайте больше мета-боксов по мере необходимости

46

Я бы хотел, чтобы пользователи могли создавать и удалять дополнительные поля метабокса по мере необходимости.

Например, скажем музыкальный подкаст с переменным количеством песен, проигрываемых в каждом эпизоде. Пользователь должен иметь возможность нажать кнопку, которая добавит дополнительные поля для ввода каждой песни по мере необходимости.

В идеале это было бы сделано без использования плагина, но закодировано в файле функций.

Picard102
источник
Вы описываете встроенные метабоксы пользовательских полей!
Bainternet
1
По сути, я думаю, что так оно и есть, но он настроен только на одно поле за раз, и это не очень удобно для конечного пользователя.
Picard102

Ответы:

52

Так ты имеешь в виду что-то подобное?

введите описание изображения здесь

и когда вы нажимаете на Добавить треки, это становится так:

введите описание изображения здесь

если это то, что вы имеете в виду, то это сделано путем создания метабокса с простой функцией jquery для добавления и удаления полей в нем, и данные сохраняются в виде массива данных в одной мета-строке:

  add_action( 'add_meta_boxes', 'dynamic_add_custom_box' );

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

    /* Adds a box to the main column on the Post and Page edit screens */
    function dynamic_add_custom_box() {
        add_meta_box(
            'dynamic_sectionid',
            __( 'My Tracks', 'myplugin_textdomain' ),
            'dynamic_inner_custom_box',
            'post');
    }

    /* Prints the box content */
    function dynamic_inner_custom_box() {
        global $post;
        // Use nonce for verification
        wp_nonce_field( plugin_basename( __FILE__ ), 'dynamicMeta_noncename' );
        ?>
        <div id="meta_inner">
        <?php

        //get the saved meta as an array
        $songs = get_post_meta($post->ID,'songs',false);

        $c = 0;
        if ( count( $songs ) > 0 ) {
            foreach( $songs as $track ) {
                if ( isset( $track['title'] ) || isset( $track['track'] ) ) {
                    printf( '<p>Song Title <input type="text" name="songs[%1$s][title]" value="%2$s" /> -- Track number : <input type="text" name="songs[%1$s][track]" value="%3$s" /><span class="remove">%4$s</span></p>', $c, $track['title'], $track['track'], __( 'Remove Track' ) );
                    $c = $c +1;
                }
            }
        }

        ?>
    <span id="here"></span>
    <span class="add"><?php _e('Add Tracks'); ?></span>
    <script>
        var $ =jQuery.noConflict();
        $(document).ready(function() {
            var count = <?php echo $c; ?>;
            $(".add").click(function() {
                count = count + 1;

                $('#here').append('<p> Song Title <input type="text" name="songs['+count+'][title]" value="" /> -- Track number : <input type="text" name="songs['+count+'][track]" value="" /><span class="remove">Remove Track</span></p>' );
                return false;
            });
// The live() method was deprecated in jQuery version 1.7, and removed in version 1.9. Use the on() method instead. We can use .on
            $(".remove").live('click', function() {
                $(this).parent().remove();
            });
        });
        </script>
    </div><?php

    }

    /* When the post is saved, saves our custom data */
    function dynamic_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;

        // verify this came from the our screen and with proper authorization,
        // because save_post can be triggered at other times
        if ( !isset( $_POST['dynamicMeta_noncename'] ) )
            return;

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

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

        $songs = $_POST['songs'];

        update_post_meta($post_id,'songs',$songs);
    }
Bainternet
источник
Кажется, он отображает «array (0) {} Add Tracks» только когда я использую приведенный выше код.
Picard102
Да просто удалитьvar_dump($songs);
Bainternet
Круто, это исправило это, но теперь данные не сохраняются при обновлении. Или, по крайней мере, данные не отображаются в виде полей в разделе «Моя дорожка» или в пользовательских полях. Если я помещу var_dump обратно, хотя он выплевывает "array (1) {[0] => array (1) {[1] => array (2) {[" title "] => string (4)" test "[" track "] => string (5)" teste "}}} Добавить треки"
Picard102
4
Не совсем уверен, в чем проблема, это не точный код, это пример и он отлично работает на моем конце, попробуйте перейти if (count($songs) > 0){наif(is_array($songs)){
Bainternet
3

Это делается с помощью настраиваемых полей, НО вы никогда не должны использовать что-либо, что позволяет пользователям добавлять создание или удаление мета-блоков. Они записываются непосредственно в базу данных, так что вы можете создать множество проблем для своего сайта, если вы предоставите пользователям такой контроль. Вам гораздо безопаснее создать максимальное количество настраиваемых полей, в которых они могут нуждаться, и оставить их пустыми там, где они не нужны.

Это тоже территория плагина. Файл функций зависит от темы, тогда как плагины предназначены для функций, которые применяются к контенту сайта, особенно если вы хотите, чтобы этот контент был доступен независимо от того, какую тему вы используете.

Некоторые предложения:

http://wordpress.org/extend/plugins/verve-meta-boxes/

http://wordpress.org/extend/plugins/more-fields/

Elpie
источник
3
НО вы никогда не должны использовать что-либо, что позволяет пользователям добавлять или удалять мета-боксы. Почему?
Трэвис Норткатт
Единственное, что меня беспокоит, так это то, что любой плагин может перестать поддерживаться в будущем. Я чувствую, что, скорее всего, мне удастся выяснить, как исправить простое дополнение к файлу функций, чем выяснить, как исправить плагин.
Picard102
Плагины - это, по сути, функции, которые находятся за пределами темы. Вы можете взять плагин и скопировать код в functions.php, и он будет работать. Точно так же вы можете извлекать функции из functions.php, добавлять необходимый заголовок для плагина, и он работает так же, как только вы активируете его.
Elpie
Хорошо знать. Я попробовал два предложенных вами плагина, но ни один из них не позволил мне действительно сделать то, что мне было нужно, что я уже не мог сделать без плагина. Спасибо за предложения, хотя.
Picard102