Я включив custom-logo
мою тему і надрукував її <?php the_custom_logo(); ?>
у заголовку. Чи є шанс просто додати до цього зображення ще кілька класів? За замовчуванням це лише комплект custom-logo
.
Я включив custom-logo
мою тему і надрукував її <?php the_custom_logo(); ?>
у заголовку. Чи є шанс просто додати до цього зображення ще кілька класів? За замовчуванням це лише комплект custom-logo
.
Відповіді:
WordPress забезпечує фільтр для підключення до налаштування логотипу. Гак get_custom_logo
- фільтр. Щоб змінити клас логотипів, цей код може вам допомогти.
add_filter( 'get_custom_logo', 'change_logo_class' );
function change_logo_class( $html ) {
$html = str_replace( 'custom-logo', 'your-custom-class', $html );
$html = str_replace( 'custom-logo-link', 'your-custom-class', $html );
return $html;
}
Довідка: Як змінити користувацький логотип Wordpress та клас посилання логотипу
Ось одна пропозиція, як ми можемо спробувати додати класи через wp_get_attachment_image_attributes
фільтр (неперевірений):
add_filter( 'wp_get_attachment_image_attributes', function( $attr )
{
if( isset( $attr['class'] ) && 'custom-logo' === $attr['class'] )
$attr['class'] = 'custom-logo foo-bar foo bar';
return $attr;
} );
де ви підганяєте заняття під свої потреби.
Як ви виявили, ви the_custom_logo
покладаєтесь на те get_custom_logo
, що саме покликає wp_get_attachment_image
додати custom-logo
клас. Остання функція має фільтр,wp_get_attachment_image_attributes
який можна використовувати для маніпулювання атрибутами зображення.
Тож, що ви можете зробити, це створити фільтр, який перевіряє, чи custom-logo
існує клас, і якщо так, додайте більше класів.
Я думаю, я знайшов одну відповідь. Але мені справді цікаво, чи це правильний шлях? Це відчувається трохи брудно: я просто скопіював пов'язані з логотипом частини з wp-include / general-template.php у свою тему function.php і перейменував функції з доданими спеціальними класами:
function FOOBAR_get_custom_logo( $blog_id = 0 ) {
$html = '';
if ( is_multisite() && (int) $blog_id !== get_current_blog_id() ) {
switch_to_blog( $blog_id );
}
$custom_logo_id = get_theme_mod( 'custom_logo' );
if ( $custom_logo_id ) {
$html = sprintf( '<a href="%1$s" class="custom-logo-link" rel="home" itemprop="url">%2$s</a>',
esc_url( home_url( '/' ) ),
wp_get_attachment_image( $custom_logo_id, 'full', false, array(
'class' => 'custom-logo FOO-BAR FOO BAR', // added classes here
'itemprop' => 'logo',
) )
);
}
elseif ( is_customize_preview() ) {
$html = sprintf( '<a href="%1$s" class="custom-logo-link" style="display:none;"><img class="custom-logo"/></a>',
esc_url( home_url( '/' ) )
);
}
if ( is_multisite() && ms_is_switched() ) {
restore_current_blog();
}
return apply_filters( 'FOOBAR_get_custom_logo', $html );
}
function FOOBAR_the_custom_logo( $blog_id = 0 ) {
echo FOOBAR_get_custom_logo( $blog_id );
}
Просто для тих, хто шукає рішення. Я це знайшов , що мені здається набагато чіткішим, ніж прийнята відповідь.
Плюс це дає прості способи змінити URL-адресу також за посиланням! Просто трохи детальніше, ніж прийнята відповідь.
add_filter( 'get_custom_logo', 'add_custom_logo_url' );
function add_custom_logo_url() {
$custom_logo_id = get_theme_mod( 'custom_logo' );
$html = sprintf( '<a href="%1$s" class="custom-logo-link" rel="home" itemprop="url">%2$s</a>',
esc_url( 'www.somewhere.com' ),
wp_get_attachment_image( $custom_logo_id, 'full', false, array(
'class' => 'custom-logo',
) )
);
return $html;
}