Użycie wp_trim_excerpt, aby wyciągnąć the_excerpt () poza pętlę


20

Tworzę motyw, który pokaże fragmenty na stronie głównej dla potencjalnie dziesiątek postów. Nie mam ręcznych fragmentów wszystkich moich postów, więc $post->post_excerptjest pusty dla wielu postów. W przypadku braku ręcznego fragmentu chciałbym użyć wbudowanej funkcji get_the_excerpt (), ale nie jest ona dostępna poza pętlą.

Śledząc funkcję, wygląda na to, że używa wp_trim_excerpt z wp-include / formatting.php do tworzenia fragmentów w locie. Nazywam to w moim kodzie wp_trim_excerpt( $item->post_content ), ale po prostu zwraca pełną treść. czy robię coś źle?

Wiem, że mogę stworzyć własną funkcję do stworzenia fragmentu, ale lubię korzystać z wbudowanych funkcji tam, gdzie to możliwe, dzięki czemu mój kod jest kompatybilny z innymi potencjalnymi wtyczkami / filtrami.

http://adambrown.info/p/wp_hooks/hook/wp_trim_excerpt?version=3.0&file=wp-includes/formatting.php


Możesz spróbować wywołać filtry fragmentów ...$myvar = apply_filters( 'the_excerpt', $myvar );
t31os 15.01.11

Odpowiedzi:



8

wp_trim_excerpt() ma trochę ciekawej mechaniki - jeśli coś zostanie przekazane, to nic nie robi.

Oto podstawowa logika:

  • get_the_excerpt() sprawdza fragment instrukcji;
  • wp_trim_excerpt() dzwoni, jeśli nie ma ręcznego fragmentu i tworzy jeden z treści lub zwiastuna.

Oba są ściśle powiązane ze zmiennymi globalnymi, więc pętla.

Poza pętlą lepiej jest wyjmować kod wp_trim_excerpt()i pisać własną funkcję przycinania.


6

Aktualizacja:

Oto pochodna wp_trim_excerpt (), której użyłem. Działa świetnie. Pochodzi z Wordpress wersja 3.0.4

function my_excerpt($text, $excerpt)
{
    if ($excerpt) return $excerpt;

    $text = strip_shortcodes( $text );

    $text = apply_filters('the_content', $text);
    $text = str_replace(']]>', ']]>', $text);
    $text = strip_tags($text);
    $excerpt_length = apply_filters('excerpt_length', 55);
    $excerpt_more = apply_filters('excerpt_more', ' ' . '[...]');
    $words = preg_split("/[\n\r\t ]+/", $text, $excerpt_length + 1, PREG_SPLIT_NO_EMPTY);
    if ( count($words) > $excerpt_length ) {
            array_pop($words);
            $text = implode(' ', $words);
            $text = $text . $excerpt_more;
    } else {
            $text = implode(' ', $words);
    }

    return apply_filters('wp_trim_excerpt', $text, $raw_excerpt);
}

Nie musisz publikować nowej odpowiedzi, zawsze możesz edytować starą, aby uwzględnić nowe informacje. Możesz na przykład skopiować link do kodu WP z pierwszej odpowiedzi na tę, a następnie usunąć pierwszą odpowiedź.
Jan Fabry

W przypadku kopii / pasterów: dodaj $ raw_excerpt = $ text;
Svetoslav Marinov,

1

Oto moje spojrzenie na „trim_excerpt”, który przyjmuje jako parametr parametr obiektu post lub identyfikator postu.

Oczywiście na podstawie tego, co jest w rdzeniu. Nie wiem, dlaczego to (i get_the_author ()) nie ma odpowiedników niepętlowych.

/**
     * Generates an excerpt from the content, if needed.
     *
     * @param int|object $post_or_id can be the post ID, or the actual $post object itself
     * @param string $excerpt_more the text that is applied to the end of the excerpt if we algorithically snip it
     * @return string the snipped excerpt or the manual excerpt if it exists         
     */
    function zg_trim_excerpt($post_or_id, $excerpt_more = ' [...]') {
        if ( is_object( $post_or_id ) ) $postObj = $post_or_id;
        else $postObj = get_post($post_or_id);

        $raw_excerpt = $text = $postObj->post_excerpt;
        if ( '' == $text ) {
            $text = $postObj->post_content;

            $text = strip_shortcodes( $text );

            $text = apply_filters('the_content', $text);
            $text = str_replace(']]>', ']]>', $text);
            $text = strip_tags($text);
            $excerpt_length = apply_filters('excerpt_length', 55);

            // don't automatically assume we will be using the global "read more" link provided by the theme
            // $excerpt_more = apply_filters('excerpt_more', ' ' . '[...]');
            $words = preg_split("/[\n\r\t ]+/", $text, $excerpt_length + 1, PREG_SPLIT_NO_EMPTY);
            if ( count($words) > $excerpt_length ) {
                array_pop($words);
                $text = implode(' ', $words);
                $text = $text . $excerpt_more;
            } else {
                $text = implode(' ', $words);
            }
        }
        return apply_filters('wp_trim_excerpt', $text, $raw_excerpt);
    }

0

+1 do Rast. To bardzo dziwne, że nie ma czegoś takiego jak get_the_excerpt ($ post-> ID), kiedy powinno być całkiem oczywiste, że powinno. W każdym razie tutaj jest wp_trim_excerpt () w wordpress wersja 3.0.4:

http://core.trac.wordpress.org/browser/tags/3.0.4/wp-include/formatting.php

function wp_trim_excerpt($text) {
1824            $raw_excerpt = $text;
1825            if ( '' == $text ) {
1826                    $text = get_the_content('');
1827    
1828                    $text = strip_shortcodes( $text );
1829    
1830                    $text = apply_filters('the_content', $text);
1831                    $text = str_replace(']]>', ']]>', $text);
1832                    $text = strip_tags($text);
1833                    $excerpt_length = apply_filters('excerpt_length', 55);
1834                    $excerpt_more = apply_filters('excerpt_more', ' ' . '[...]');
1835                    $words = preg_split("/[\n\r\t ]+/", $text, $excerpt_length + 1, PREG_SPLIT_NO_EMPTY);
1836                    if ( count($words) > $excerpt_length ) {
1837                            array_pop($words);
1838                            $text = implode(' ', $words);
1839                            $text = $text . $excerpt_more;
1840                    } else {
1841                            $text = implode(' ', $words);
1842                    }
1843            }
1844            return apply_filters('wp_trim_excerpt', $text, $raw_excerpt);
1845    }

W wierszu 1826 widać, że jest on powiązany ze zmienną globalną $ post za pośrednictwem get_the_contents. I tak, nie mam pojęcia o czym oni myśleli. Ale odtąd zamień get_the_content na $ text we własnym my_excerpt i powinien on zachowywać się w podobny sposób.


azure_ardee : rozważ użycie wp_trim_words ()

0

Funkcja get_the_content () zwróci pełną treść, jeśli $ more! = 0. Musisz ustawić zmienną globalną $ more na 0, aby mieć pewność, że funkcja get_the_content () zwróci fragment.

Zmodyfikowana funkcja wp_trim_excerpt ():

function wp_trim_excerpt($text) {
    $raw_excerpt = $text;
    if ( '' == $text ) {
        global $more;
        $tmp = $more;
        $more = 0;
        $text = get_the_content('');
        $more = $tmp;

        $text = strip_shortcodes( $text );

        $text = apply_filters('the_content', $text);
        $text = str_replace(']]>', ']]>', $text);
        $text = strip_tags($text);
        $excerpt_length = apply_filters('excerpt_length', 55);
        $excerpt_more = apply_filters('excerpt_more', ' ' . '[...]');
        $words = preg_split("/[\n\r\t ]+/", $text, $excerpt_length + 1, PREG_SPLIT_NO_EMPTY);
        if ( count($words) > $excerpt_length ) {
            array_pop($words);
            $text = implode(' ', $words);
            $text = $text . $excerpt_more;
        } else {
            $text = implode(' ', $words);
        }
    }
    return apply_filters('wp_trim_excerpt', $text, $raw_excerpt);
}

0

Korzystając z powyższych odpowiedzi innych, oto prostsza odpowiedź, która wydaje się działać dobrze:

global $post;

$excerpt = apply_filters('get_the_excerpt', get_post_field('post_excerpt', $post->ID));

if ( $excerpt == '' ) {
    $excerpt = wp_trim_words( $post->post_content, 55 );
}

Używam go w <meta>tagach w funkcji do definiowania opisów OpenGraph. Więc po prostu dodaję:

<meta property="og:description" content="<?php echo esc_html( $excerpt ); ?>" />

Co z treścią HTML? Jak poradzi sobie z tagami? fragment usuwa również tagi HTML i skróty. co jeśli pierwsze słowa fragmentu zawierają obraz? To prawdopodobnie zepsuje twój układ.
brett
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.