9 сентября 2010 г.

Я уже неоднократно говорил такую мысль, что, если есть возможность сделать какую-либо функцию без плагина, то лучше отказаться от него, т.к. он создает дополнительную нагрузку на сервер из-за обращений к БД и т.п.

Хочу показать пример, как можно обойтись без использования плагина “SEO Title Tag“, использовав простейший код. Если кто не понял, речь пойдет про HTML-тег <title></title>.

Естественно, мое решение не реализует всех функций, которые этим плагином предусмотрены, но те функции, ради которых я ранее использовал этот плагин, оно позволяет сделать. А использовал я этот плагин для следующего:

  1. Добавление названия блога на все страницы.
  2. Вывод названия блога после заголовка статьи, а не наоборот, т.е. вида Заголовок статьи » Название сайта.
  3. Произвольный заголовок для страницы с ошибкой 404.
  4. Использование 2-х разных заголовков статьи: 1-й – в теге <title></title>, 2-й – непосредственно на странице.

Читать далее »

Если на WordPress-сайте в настройках активирована опция древовидных комментариев, то под каждый комментарием появляется ссылка “ответить”, за исключением последнего уровня вложенности.

Верстая шаблоны для WordPress, мне не раз приходилось сталкиваться с необходимостью оформления этой ссылки, например, вот так:

Ссылка 'Ответить на комментарий'

Исходный код ссылки “ответить”, согласно стандартному коду WordPress, выглядит следующим образом:

<div class="reply">
	<?php comment_reply_link(array_merge( $args, array('depth' => $depth, 'max_depth' => $args['max_depth']))) ?>
</div>

Второй комментарий, который на скриншоте – это последний уровень в дереве, т.е. в нем ссылка “ответить” не выводится. Но, оформление, как мы видим, осталось.

Так происходит потому, что ссылка исчезает, а блок <div class="reply"></div> остается, а поскольку к нему применены CSS-стили, поэтому наблюдаем такую некрасивость, как на скриншоте.

Я поэкспериментировал с PHP-кодом, чтобы получить условие, которое позволит исчезать этому блоку одновременно с исчезновением ссылки, и у меня получилось вот такое решение:

<?php if (comments_open() AND (get_option('thread_comments') == 1) AND ($depth != $args['max_depth'])) { ?>
		<div class="reply">
			<?php comment_reply_link(array_merge( $args, array('add_below' => 'div-comment', 'depth' => $depth, 'max_depth' => $args['max_depth']))) ?>
		</div>
<?php } ?>

Его нужно использовать вместо того кода, который я привел выше.

—–

Лидер в производстве детских развивающих игрушек представляет трехколесный велосипед Smoby с ручкой, в стиле Принцессы Диснея, приобрести который можно в детском интернет-магазине BABADU.RU.

При вставке в текст поста тега <!--more--> WordPress добавляет к ссылке “читать далее” якорь вида #more-123 (цифра – это ID поста), чтобы при переходе по этой ссылке переместиться в то место, где этот тег вставлен. На мой взгляд, это совершенно ненужная вещь, и от нее можно легко избавиться.

В файл functions.php темы необходимо поместить следующий код:

function no_more_jumping($post) {
	return '<a href="'.get_permalink($post->ID).'" class="read-more">'.'Читать далее &raquo;'.'</a>';
}
add_filter('the_content_more_link', 'no_more_jumping');

Вот и все.

Облако тегов