Как я могу изменить вывод виджета WordPress по умолчанию?

17

Я не хочу стилизовать виджет по умолчанию только с CSS. Я хочу отобразить содержимое виджета «Категории» по умолчанию с моей собственной структурой HTML.

Есть ли какой-нибудь фильтр или крючок для этого?

Эх Джуэл
источник
2
Напишите свой собственный виджет, который делает то, что вы хотите. Начните с копирования кода виджета категорий и внесите изменения.
Марк Каплун
Спасибо, я обычно следую этому трюку, чтобы внести изменения в виджет. Мне кажется, это более простой метод.
Эх Джевел

Ответы:

13

Чтобы расширить ответ Марка, в стандартных виджетах WordPress (в большинстве случаев) доступно немного (в общем) способов фильтров widget_text.

Но добавить свой собственный виджет легко - поместите это в functions.php:

require_once("my_widget.php");
add_action("widgets_init", "my_custom_widgets_init");

function my_custom_widgets_init(){
  register_widget("My_Custom_Widget_Class");
}

Тогда вы просто хотите скопировать существующие категории виджета от wp-includes/widgets/class-wp-widget-categories.phpк my_widget.phpвашей теме, и изменить имя класса с тем же именем, что используется в вызове register_widget()выше.

Затем внесите любые изменения, которые вам нравятся! Я предлагаю также изменить заголовок, чтобы вы могли отличить его от стандартного виджета «Категории».

Тим Мэлоун
источник
10

Вы можете переопределить стандартные виджеты WordPress, расширив их. Код для виджета Категории по умолчанию можно найти по следующей ссылке: https://developer.wordpress.org/reference/classes/wp_widget_categories/widget/

и ниже приведен пример кода, как вы можете переопределить вывод виджета.

Class My_Categories_Widget extends WP_Widget_Categories {
    function widget( $args, $instance ) {
        // your code here for overriding the output of the widget
    }
}

function my_categories_widget_register() {
    unregister_widget( 'WP_Widget_Categories' );
    register_widget( 'My_Categories_Widget' );
}
add_action( 'widgets_init', 'my_categories_widget_register' );
Борис Кузманов
источник
1
И причина, по которой я не предлагал это в качестве опции, заключается в том, что вам может понадобиться исходное поведение в какой-то момент, а с вашим решением вы просто потеряете возможность его получить.
Марк Каплун
Да, если вы хотите использовать виджет по умолчанию, лучше зарегистрировать совершенно новый виджет. codex.wordpress.org/Function_Reference/register_widget
Борис Кузманов
8

Вам не нужно создавать совершенно новый виджет, чтобы делать то, что вам нужно. Когда я читаю ваш вопрос, вы просто заинтересованы в изменении способа отображения категорий в интерфейсе. Есть две функции, которые отображают категории на переднем конце

Все зависит от того, какой вариант был выбран в бэкэнде

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

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

Они соответственно

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

Короче говоря, вы можете попробовать следующее: ( ПОЛНОСТЬЮ НЕПРОВЕРЕНО )

add_filter( 'widget_title', function( $title, $instance, $id_base )
{
    // Target the categories base
    if( 'categories' === $id_base ) // Just make sure the base is correct, I'm not sure here
        add_filter( 'wp_list_categories', 'wpse_229772_categories', 11, 2 );
        //add_filter( 'wp_dropdown_cats', 'wpse_229772_categories', 11, 2 );
    return $title;
}, 10, 3 );

function wpse_229772_categories( $output, $args )
{
    // Only run the filter once
    remove_filter( current_filter(), __FUNCTION__ );

    // Get all the categories
    $categories = get_categories( $args );

    $output = '';
    // Just an example of custom html
    $output .= '<div class="some class">';
    foreach ( $categories as $category ) {
        // Just an example of custom html
        $output .= '<div class="' . echo $category->term_id . '">';
        // You can add any other info here, like a link to the category
        $output .= $category->name;
        // etc ect, you get the drift
        $output .= '</div>';
    }
    $output .= '</div>';

    return $output;
}, 11, 2 );
Питер Гусен
источник