Як надати користувальницьку назву з посиланнями на посилання?


14

Я розділив вміст своєї публікації на неодноразові сторінки за допомогою <! - nextpage ->коду. Я хочу дати своїм болючим посиланням власну назву замість звичайної 1,2,3. Як я можу це зробити? причина в цьому документі https://codex.wordpress.org/Styling_Page- Посилається, що він лише згадує спосіб додавання суфікса чи префікса. Я просто хочу надати кожному підключеному номеру свій власний власний заголовок

Відповіді:


17

Ось спосіб підтримати заголовки сторінки у формі:

<!--nextpage(.*?)?--> 

по-простому, як підтримує ядро <!--more(.*?)?-->.

Ось приклад:

<!--nextpage Planets -->
Let's talk about the Planets
<!--nextpage Mercury -->
Exotic Mercury
<!--nextpage Venus-->
Beautiful Venus
<!--nextpage Earth -->
Our Blue Earth
<!--nextpage Mars -->
The Red Planet

з виходом аналогічним:

Назви сторінок

Це було перевірено на тему « Двадцять шістнадцять» , де мені довелося трохи відрегулювати прокладку та ширину :

.page-links a, .page-links > span {
    width:   auto;
    padding: 0 5px;
}

Демонстраційний плагін

Ось демонстраційний плагін , який використовує content_pagination, wp_link_pages_link, pre_handle_404і wp_link_pages_argsфільтри , щоб підтримати цю extenstion з СледующаяСтраніци маркерів ( PHP 5.4+ ):

<?php
/**
 * Plugin Name: Content Pagination Titles
 * Description: Support for &lt;!--nextpage(.*?)?--&gt; in the post content
 * Version:     1.0.1
 * Plugin URI:  http://wordpress.stackexchange.com/a/227022/26350
 */

namespace WPSE\Question202709;

add_action( 'init', function()
{
    $main = new Main;
    $main->init();
} );

class Main
{
    private $pagination_titles;

    public function init()
    {
        add_filter( 'pre_handle_404',       [ $this, 'pre_handle_404' ],        10, 2       );
        add_filter( 'content_pagination',   [ $this, 'content_pagination' ],    -1, 2       );
        add_filter( 'wp_link_pages_link',   [ $this, 'wp_link_pages_link' ],    10, 2       );
        add_filter( 'wp_link_pages_args',   [ $this, 'wp_link_pages_args' ],    PHP_INT_MAX );
    }

    public function content_pagination( $pages, $post )
    {
        // Empty content pagination titles for each run
        $this->pagination_titles = [];

        // Nothing to do if the post content doesn't contain pagination titles
        if( false === stripos( $post->post_content, '<!--nextpage' ) )
            return $pages;

        // Collect pagination titles
        preg_match_all( '/<!--nextpage(.*?)?-->/i', $post->post_content, $matches );
        if( isset( $matches[1] ) )
            $this->pagination_titles = $matches[1];     

        // Override $pages according to our new extended nextpage support
        $pages = preg_split( '/<!--nextpage(.*?)?-->/i', $post->post_content );

        // nextpage marker at the top
        if( isset( $pages[0] ) && '' == trim( $pages[0] ) )
        {
            // remove the empty page
            array_shift( $pages );
        }       
        // nextpage marker not at the top
        else
        {
            // add the first numeric pagination title 
            array_unshift( $this->pagination_titles, '1' );
        }           
        return $pages;
    }

    public function wp_link_pages_link( $link, $i )
    {
        if( ! empty( $this->pagination_titles ) )
        {
            $from  = '{{TITLE}}';
            $to    = ! empty( $this->pagination_titles[$i-1] ) ? $this->pagination_titles[$i-1] : $i;
            $link  = str_replace( $from, $to, $link );
        }

        return $link;
    }

    public function wp_link_pages_args( $params )
    {       
        if( ! empty( $this->pagination_titles ) )
        {
            $params['next_or_number'] = 'number';
            $params['pagelink'] = str_replace( '%', '{{TITLE}}', $params['pagelink'] );
        }
        return $params;
    }

    /**
     * Based on the nextpage check in WP::handle_404()
     */
    public function pre_handle_404( $bool, \WP_Query $q )
    {
        global $wp;

        if( $q->posts && is_singular() )
        {
            if ( $q->post instanceof \WP_Post ) 
                $p = clone $q->post;

            // check for paged content that exceeds the max number of pages
            $next = '<!--nextpage';
            if (   $p 
                 && false !== stripos( $p->post_content, $next ) 
                 && ! empty( $wp->query_vars['page'] ) 
            ) {
                $page = trim( $wp->query_vars['page'], '/' );
                $success = (int) $page <= ( substr_count( $p->post_content, $next ) + 1 );

                if ( $success )
                {
                    status_header( 200 );
                    $bool = true;
                }
            }
        }
        return $bool;
    }

} // end class

Установка : Створіть /wp-content/plugins/content-pagination-titles/content-pagination-titles.phpфайл та активуйте плагін. Завжди хороша ідея для резервного копіювання перед тестуванням будь-якого плагіна.

Якщо верхній СледующаяСтраніца маркер відсутня, то перша назва пагінацію числове.

Крім того, якщо заголовок сторінки з вмістом відсутній, тобто <!--nextpage-->він буде числовим, як і очікувалося.

Я перший забув про СледующаяСтраніце помилки в WPкласі, який з'являється, якщо ми змінюємо кількість сторінок через content_paginationфільтр. Про це нещодавно повідомив @PieterGoosen тут у # 35562 .

Ми намагаємося подолати це в нашому демо-плагіні із pre_handle_404зворотним зворотом фільтрів на основі WPкласової перевірки тут , де ми перевіряємо <!--nextpageзамість <!--nextpage-->.

Тести

Ось кілька додаткових тестів:

Тест №1

<!--nextpage-->
Let's talk about the Planets
<!--nextpage-->
Exotic Mercury
<!--nextpage-->
Beautiful Venus
<!--nextpage-->
Our Blue Earth
<!--nextpage-->
The Red Planet

Вихід для 1 вибраного:

тест1

як і очікувалося.

Тест №2

Let's talk about the Planets
<!--nextpage-->
Exotic Mercury
<!--nextpage-->
Beautiful Venus
<!--nextpage-->
Our Blue Earth
<!--nextpage-->
The Red Planet

Вихід для 5 обраних:

тест2

як і очікувалося.

Тест №3

<!--nextpage-->
Let's talk about the Planets
<!--nextpage Mercury-->
Exotic Mercury
<!--nextpage-->
Beautiful Venus
<!--nextpage Earth -->
Our Blue Earth
<!--nextpage Mars -->
The Red Planet

Вихід для 3 обраних:

тест3

як і очікувалося.

Тест №4

Let's talk about the Planets
<!--nextpage Mercury-->
Exotic Mercury
<!--nextpage Venus-->
Beautiful Venus
<!--nextpage Earth -->
Our Blue Earth
<!--nextpage Mars -->
The Red Planet

Вихід із Землею вибрано:

тест4

як і очікувалося.

Альтернативи

Іншим способом було б змінити його, щоб підтримувати заголовки сторінки, які слід додати:

<!--pt Earth-->

Також може бути корисно підтримати єдиний коментар для всіх назв сторінки ( очок ):

<!--pts Planets|Mercury|Venus|Earth|Mars -->

чи, можливо, через користувацькі поля?


Це виглядає цікаво і досить динамічно. ;-)
Пітер Гусен

+1 для техніки закриття;) До цього я лише знав, що ми обмежені apply_filterаргументами: D
Суміт

1
Це може бути зручно при написанні коротких фрагментів коду на WPSE, але ми також можемо просто написати клас, щоб підтримати це у належному плагіні ;-) @Sumit
birgire

@PieterGoosen Я вперше забув про помилку №35562 , спробував налаштувати її через pre_handle_404фільтр.
birgire

@birgire Я думав про це питання, але не міг нічого перевірити, щоб підтвердити чи знехтувати вплив цього питання, я настільки захопився іншими проектами, що не потребують ПК. Схоже, помилка залишиться надовго. Раніше я тестував нові та старі версії, і мої висновки полягають у тому, що код, що викликає помилку, може бути видалений з ядра, поки хтось не знайде належне рішення ... ;-)
Пітер Гузен

5

Можна використовувати фільтр wp_link_pages_link

Спочатку передайте наш спеціальний заповнювач рядків (Це може бути все, що вам подобається, крім рядка, що містить %лише зараз я використовую #custom_title#).

wp_link_pages( array( 'pagelink' => '#custom_title#' ) );

Потім додайте наш фільтр functions.php. У функції зворотного дзвінка складіть масив заголовків, після чого перевірте номер поточної сторінки та замініть #custom_title#значенням, що відповідає номеру поточної сторінки.

Приклад: -

add_filter('wp_link_pages_link', 'wp_link_pages_link_custom_title', 10, 2);
/**
 * Replace placeholder with custom titles
 * @param string $link Page link HTML
 * @param int $i Current page number
 * @return string $link Page link HTML
 */
function wp_link_pages_link_custom_title($link, $i) {

    //Define array of custom titles
    $custom_titles = array(
        __('Custom title A', 'text-domain'),
        __('Custom title B', 'text-domain'),
        __('Custom title C', 'text-domain'),
    );

    //Default title when title is not set in array
    $default_title = __('Page', 'text-domain') . ' ' . $i; 

    $i--; //Decrease the value by 1 because our array start with 0

    if (isset($custom_titles[$i])) { //Check if title exist in array if yes then replace it
        $link = str_replace('#custom_title#', $custom_titles[$i], $link);
    } else { //Replace with default title
        $link = str_replace('#custom_title#', $default_title, $link);
    }

    return $link;
}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.