mauri
  • 0
Новичок

Цикл PHP, который выбирает сообщения с определенной опцией в сообщении

  • 0

Я пытаюсь создать слайдер избранного поста, чтобы показывать любой пост, который я mark as a "featured" (с опцией в посте), независимо от категории или типа тега… Я новичок в wordpress, и хотя я немного понимаю язык php, я не кодер 🙁

Слайдер уже работает. Вопрос в том, как я могу создать этот слайдер с циклом, чтобы показать последний 7 пост, помеченный как «избранный» с соответствующим избранным изображением?

У меня уже есть опция «В сообщении», настроенная в метабоксе на странице редактирования сообщения, а также размер изображения, настроенный в моем файле function.php…

Я использую wordpress 3.1 с фреймворком genesis.

Вот код слайдера

<div class="slider">
    <ul class="main-wapper">
      <li> <img src="path to featured img" title="the post title" height="300" width="315">
        <div class="main-item-desc">
          <h2><a target="_parent" title="Post Title" href="post link">POST TITLE</a></h2>
          <p>Post Description limited to 150 character</p>
        </div>
      </li>
      <li> <img src="path to featured img" title="the post title" height="300" width="315">
        <div class="main-item-desc">
          <h2><a target="_parent" title="Post Title" href="post link">POST TITLE</a></h2>
          <p>Post Description limited to 150 character</p>
        </div>
      </li>
      <li> <img src="path to featured img" title="the post title" height="300" width="315">
        <div class="main-item-desc">
          <h2><a target="_parent" title="Post Title" href="post link">POST TITLE</a></h2>
          <p>Post Description limited to 150 character</p>
        </div>
      </li>
      <li> <img src="path to featured img" title="the post title" height="300" width="315">
        <div class="main-item-desc">
          <h2><a target="_parent" title="Post Title" href="post link">POST TITLE</a></h2>
          <p>Post Description limited to 150 character</p>
        </div>
      </li>
      </ul>
  </div>
  <div class="navigator-outer">
    <ul class="navigator">
      <li>
        <div> <img src="img src" />
          <h3>Content Title H3</h3>
          <p><span class="date">20.01.2010</span> | <span class="category">CATEGORY NAME</span></p></div>
      </li>
      <li>
        <div> <img src="img src" />
          <h3>Content Title H3</h3>
          <p><span class="date">20.01.2010</span> | <span class="category">CATEGORY NAME</span></p></div>
      </li>
      <li>
        <div> <img src="img src" />
          <h3>Content Title H3</h3>
          <p><span class="date">20.01.2010</span> | <span class="category">CATEGORY NAME</span></p></div>
      </li>
      <li>
        <div> <img src="img src" />
          <h3>Content Title H3</h3>
          <p><span class="date">20.01.2010</span> | <span class="category">CATEGORY NAME</span></p></div>
      </li>

    </ul>
  </div>
</div>

вот скрин слайдера..Слайдер Скриншот

ОБНОВЛЕНИЕ: в моих файлах functions.php у меня есть это..

// Add new image sizes
add_image_size('Slider', 315, 300, TRUE);

require_once(CHILD_DIR . '/lib/admin/inpost-settings.php');
wich is the code below..

inpost-settings.php

$prefix = 'myslider_';

$meta_box = array(
    'id' => 'slider-meta-box',
    'title' => 'Featured Slider Options',
    'page' => 'post',
    'context' => 'normal',
    'priority' => 'high',
    'fields' => array(
        array(
            'name' => 'Show in featured slider',
            'id' => $prefix . 'show_post_slider',
            'type' => 'checkbox'
        )
    )
);
add_action('admin_menu', 'mytheme_add_box');

// Add meta box
function mytheme_add_box() {
    global $meta_box;

    add_meta_box($meta_box['id'], $meta_box['title'], 'mytheme_show_box', $meta_box['page'], $meta_box['context'], $meta_box['priority']);
}

// Callback function to show fields in meta box
function mytheme_show_box() {
    global $meta_box, $post;

    // Use nonce for verification
    echo '<input type="hidden" name="mytheme_meta_box_nonce" value="', wp_create_nonce(basename(__FILE__)), '" />';

    echo '<table class="form-table">';

    foreach ($meta_box['fields'] as $field) {
        // get current post meta data
        $meta = get_post_meta($post->ID, $field['id'], true);

        echo '<tr>',
                '<th style="width:20%"><label for="', $field['id'], '">', $field['name'], '</label></th>',
                '<td>';
        switch ($field['type']) {
             case 'checkbox':
                echo '<input type="checkbox" name="', $field['id'], '" id="', $field['id'], '"', $meta ? ' checked="checked"' : '', ' />';
                break;
        }
        echo     '<td>',
            '</tr>';
    }

    echo '</table>';
}
add_action('save_post', 'mytheme_save_data');

// Save data from meta box
function mytheme_save_data($post_id) {
    global $meta_box;

    // verify nonce
    if (!wp_verify_nonce($_POST['mytheme_meta_box_nonce'], basename(__FILE__))) {
        return $post_id;
    }

    // check autosave
    if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE) {
        return $post_id;
    }

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

    foreach ($meta_box['fields'] as $field) {
        $old = get_post_meta($post_id, $field['id'], true);
        $new = $_POST[$field['id']];

        if ($new && $new != $old) {
            update_post_meta($post_id, $field['id'], $new);
        } elseif ('' == $new && $old) {
            delete_post_meta($post_id, $field['id'], $old);
        }
    }
}
// check autosave
if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE) {
 return $post_id;
}

Заранее спасибо.

Share
  1. Просто для небольшого пояснения: вам нужна помощь в преобразовании вышеприведенного статического HTML в цикл PHP, который выбирает сообщения с определенным мета-ключом и создает соответствующий HTML?

    • 0
  2. Все, что вам нужно, это простой запрос и повторение этого запроса пару раз, чтобы вы могли построить два необходимых списка. WP_Query имеет удобный метод для сброса указателя в массиве сообщений, поэтому вы можете снова перебрать его, rewind_posts хотя я считаю, что внутри пользовательских циклов вы должны напрямую ссылаться на метод.

    В любом случае, вот то, что вы ищете, просто внесите необходимые коррективы.

    <?php   
        $featured = new WP_Query;
        $featured->query( array( 
            'meta_query'  => array( 
                array(
                    'key'     => 'myslider_show_post_slider',
                    'value'   => array('on','1'),
                    'compare' => 'IN',
                    'type'    => 'CHAR',
                )
            ),
            'post_type'       => 'post',
            'post_status'     => 'publish',
            'ignore_sticky_posts' => '1',
            'posts_per_page' => '7' //The number of post in the slider.
        ) );
        if( $featured->have_posts() ) :
        ?>
    
        <div class="slider">
            <ul class="main-wapper">
    
            <?php
            while( $featured->have_posts() ) : $featured->the_post();
            ?>
    
            <li>
                <?php the_post_thumbnail(); ?>
                <div class="main-item-desc">
                    <h2><a title="<?php the_title_attribute(); ?>" href="<?php the_permalink(); ?>"><?php the_title(); ?></a></h2>
                    <p>Where's this description suppose to be coming from?</p>
                </div>
          </li>
    
            <?php
            endwhile;
            $featured->rewind_posts();
            ?>
    
            </ul>
        </div>
        <div class="navigator-outer">
            <ul class="navigator">
    
            <?php
            while( $featured->have_posts() ) : $featured->the_post();
            ?>
    
            <li>
                <div>
                     <?php the_post_thumbnail('Slider'); ?>
                    <h3><?php the_title(); ?></h3>
                    <p><span class="date"><?php the_time( 'd.m.Y' ); ?></span> | <span class="category"><?php the_category(','); ?></span></p>
                </div>
            </li>
    
            <?php
            endwhile;
            ?>
    
            </ul>
        </div>
    
        <?php
        endif; 
        ?>
    

    Во-первых, в опубликованном вами HTML-коде был случайный закрывающий DIV, поэтому я просто удалил его из приведенного выше кода.

    Во-вторых, для флажка не указано значение, в таких случаях флажку не присваивается определенное значение, браузер назначает флажку одно, я не уверен, есть ли общее значение, которое будут использовать все браузеры, но Firefox выдает значение on, но я учел возможность того, что браузер может присвоить значение 1, в идеале флажку должно быть присвоено неявное значение, чтобы обеспечить согласованное поведение, например..

    echo '<input type="checkbox" value="1" name="', $field['id'], '" id="', $field['id'], '"', $meta ? ' checked="checked"' : '', ' />';
    

    Любые вопросы, дай мне знать..

    • 0

Оставить ответ

You must login to add an answer.