Как получить следующее или предыдущее сообщение в определенном теге?

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

Я хочу смочь к чему-то вроде этого, появляясь ниже сообщения.

get_previous_link("tagname");
get_next_link("tagname");

Кто-либо знает о способе выполнить это? Иначе я должен буду записать что-то сам, которое прекрасно, но я полагал, что не изобрету велосипед, если я не буду иметь к.

6
07.04.2011, 09:10
3 ответа

get_adjacent_post(), который используется всеми функциями, которые возвращаются (свяжитесь с), следующее или предыдущее сообщение, только имеет a $in_same_cat аргумент, который смотрит на категории сообщение, находится в, не теги.

Вы могли сцепиться в get_[next|previous]_post_join для изменения запроса соединения для вызова но затем, вероятно, легче скопировать функцию, удалить определенный для категории код и заменить его определенным для тега кодом. Или сделайте это еще более универсальным и отправьте его как патч к WordPress :-)

6
19.02.2020, 22:05
  • 1
    Да, я нашел, что функция, надеялся, что кто-то еще уже записал этому =) –  The How-To Geek 07.04.2011, 09:45

Это работает на ту проблему? http://digwp.com/2010/04/post-navigation-outside-loop/

Код в том сообщении работает на "Страницы Представления Архива" и "Страницы Единственного Представления" :P

1
19.02.2020, 22:05
  • 1
    Это не дает мне определенные ссылки тега. –  The How-To Geek 07.04.2011, 09:44

Вот версия скопировать/вставить редактирование, что @Jan Fabry сослался на вышеупомянутый (определенно не самое изящное решение, но это должно работать):

/**
 * Retrieve adjacent post.
 *
 * Can either be next or previous post.
 *
 *
 * @param bool $in_same_tag Optional. Whether post should be in same category.
 * @param string $excluded_tags Optional. Excluded tags IDs.
 * @param bool $previous Optional. Whether to retrieve previous post.
 * @return mixed Post object if successful. Null if global $post is not set. Empty string if no corresponding post exists.
 */
function get_adjacent_post_by_tag($in_same_tag = false, $excluded_tags = '', $previous = true) {
    global $post, $wpdb;

    if ( empty( $post ) )
        return null;

    $current_post_date = $post->post_date;

    $join = '';
    $posts_in_ex_tags_sql = '';
    if ( $in_same_tag || !empty($excluded_tags) ) {
        $join = " INNER JOIN $wpdb->term_relationships AS tr ON p.ID = tr.object_id INNER JOIN $wpdb->term_taxonomy tt ON tr.term_taxonomy_id = tt.term_taxonomy_id";

        if ( $in_same_tag ) {
            $tag_array = wp_get_object_terms($post->ID, 'post_tag', array('fields' => 'ids'));
            $join .= " AND tt.taxonomy = 'post_tag' AND tt.term_id IN (" . implode(',', $tag_array) . ")";
        }

        $posts_in_ex_tags_sql = "AND tt.taxonomy = 'post_tag'";
        if ( !empty($excluded_tags) ) {
            $excluded_tags = array_map('intval', explode(' and ', $excluded_tags));
            if ( !empty($tag_array) ) {
                $excluded_tags = array_diff($excluded_tags, $tag_array);
                $posts_in_ex_tags_sql = '';
            }

            if ( !empty($excluded_tags) ) {
                $posts_in_ex_tags_sql = " AND tt.taxonomy = 'post_tag' AND tt.term_id NOT IN (" . implode($excluded_tags, ',') . ')';
            }
        }
    }

    $adjacent = $previous ? 'previous' : 'next';
    $op = $previous ? '<' : '>';
    $order = $previous ? 'DESC' : 'ASC';

    $join  = apply_filters( "get_{$adjacent}_post_join", $join, $in_same_tag, $excluded_tags );
    $where = apply_filters( "get_{$adjacent}_post_where", $wpdb->prepare("WHERE p.post_date $op %s AND p.post_type = %s AND p.post_status = 'publish' $posts_in_ex_tags_sql", $current_post_date, $post->post_type), $in_same_tag, $excluded_tags );
    $sort  = apply_filters( "get_{$adjacent}_post_sort", "ORDER BY p.post_date $order LIMIT 1" );

    $query = "SELECT p.* FROM $wpdb->posts AS p $join $where $sort";
    $query_key = 'adjacent_post_' . md5($query);
    $result = wp_cache_get($query_key, 'counts');
    if ( false !== $result )
        return $result;

    $result = $wpdb->get_row("SELECT p.* FROM $wpdb->posts AS p $join $where $sort");
    if ( null === $result )
        $result = '';

    wp_cache_set($query_key, $result, 'counts');
    return $result;
}
1
19.02.2020, 22:05