Произвольный заголовок H1 для категорий WordPress/Woocommerce

Комментариев: 0

Каждый сайт, который сталкивается с задачей SEO-оптимизации нуждается в альтернативных заголовках H1 для страниц сайта. Например, есть у вас категория "Плитка", и вложенная в неё категория "Керамическая". Вроде бы всё логично, но если человек попадает на страницу "Керамическая", то здесь так и просится " Керамическая плитка". В хлебных крошах тоже не хочется отображать Плитка -> Керамическая плитка, а хочет просто "Плитка ->Керамическая".

Короче, что-то я тут объясняю, вы всё это уже понимаете, поэтому вот вам очень простое решение, которое я использую на своих проектах (решение не моё, где-то находил):

<?php
$taxname = 'product_cat'; //В данном случае сработает для Woocommerce.

add_action("{$taxname}_add_form_fields", 'add_new_custom_fields');
add_action("{$taxname}_edit_form_fields", 'edit_new_custom_fields');
add_action("create_{$taxname}", 'save_custom_taxonomy_meta');
add_action("edited_{$taxname}", 'save_custom_taxonomy_meta');

function edit_new_custom_fields( $term ) {
	?>
		<tr class="form-field">
			<th scope="row" valign="top"><label>Заголовок H1</label></th>
			<td>
				<input type="text" name="extra[title]" value="<?php echo esc_attr( get_term_meta( $term->term_id, 'title', 1 ) ) ?>"><br />
				<span class="description">SEO заголовок (h1)</span>
			</td>
		</tr>
		
	<?php
}

function add_new_custom_fields( $taxonomy_slug ){
	?>
	<div class="form-field">
		<label for="tag-title">Заголовок H1</label>
		<input name="extra[title]" id="tag-title" type="text" value="" />
		<p>SEO заголовок (h1)</p>
	</div>
	
	<?php
}

function save_custom_taxonomy_meta( $term_id ) {
	if ( ! isset($_POST['extra']) ) return;
	if ( ! current_user_can('edit_term', $term_id) ) return;
	if (
		! wp_verify_nonce( $_POST['_wpnonce'], "update-tag_$term_id" ) && // wp_nonce_field( 'update-tag_' . $tag_ID );
		! wp_verify_nonce( $_POST['_wpnonce_add-tag'], "add-tag" ) // wp_nonce_field('add-tag', '_wpnonce_add-tag');
	) return;
	$extra = wp_unslash($_POST['extra']);

	foreach( $extra as $key => $val ){
		$_key = sanitize_key( $key );
		if( $_key !== $key ) wp_die( 'bad key'. esc_html($key) );
		if( $_key === 'tag_posts_shortcode_links' )
			$val = sanitize_textarea_field( strip_tags($val) );
		else
			$val = sanitize_text_field( $val );
		if( ! $val )
			delete_term_meta( $term_id, $_key );
		else
			update_term_meta( $term_id, $_key, $val );
	}

	return $term_id;
}
?>

Ну и теперь осталось вывести его в замен текущему заголовку. Но, было бы правильно выводить обычное название, если не указано альтернативное, как-то так:

<?php
if (!empty(get_queried_object()->term_id)) {
	$id = get_queried_object()->term_id;
}				
$title =  get_term_meta($id , 'title', 1 ); // Теперь в этой переменной h1 заголовок
	if ($title) {
	    echo $title;
	} else {
	   echo woocommerce_page_title(); //Для Woocommerce
	}
?>

Метки:

Отправить ответ

avatar
  Уведомлять о новых комментариях  
Уведомлять