WordPress — это не только очень хорошая CMS и движок для блога, но и, помимо всего прочего, еще и… RSS-ридер. Чтобы превратить WP в читалку ваших любимых RSS-лент, достаточно выполнить одно простейшее действие: вставить следующий код в нужное место (там, где вы хотите видеть эти фиды), например, это может быть свой шаблон страницы.
Твиттер сегодня, что назвается, “наше все” и сервисы к нему появляются (и умирают) с фантастической скоростью. Одним из десятков (если уже не сотен) является сервис TweetMeme, который можно назвать своего рода “Digg для Твиттер”. Кому не хотелось бы, чтобы посты с его блога отправлялись на TweetMeme с такой же легкостью, как и на Digg? Для этого умные люди (то есть не я :)) придумали простое решение.
В functions.php вашей темы добавьте вот такой простой код:
function tweetmeme(){
return '
';
}
add_shortcode('tweet', 'tweetmeme');
и… все! Теперь при написании поста, вставьте в пост (в HTML-режиме) шорт-код [tweet] и он отобразит кнопку от TweetMeme.
(Когда писать особо не о чем, а ГосДеп требует отрабатывать вложенное бабло – приходиться заниматься переводами, ибо большинство оф. планктона, которое хочет приобщиться к волшебному миру WP, все равно не может ни черта прочитать на иностранных источниках.)
Ну тогда вот вам простенький пример: как отобразить комментарии к посту прямо под ним на главной странице. Берется вот такой код:
< ?php
global $withcomments;
$withcomments = true;
comments_template("/inline-comments.php");
?>
и вставляется в нужное место в файле index.php
Файл inline-comments.php понадобится как шаблон для правильного форматирования комментариев. Можно, конечно, извратиться и использовать файл comments.php, но т.к. там предусмотрено форматирование отображение комментариев для отдельной записи, можно быть увереным, что результат будет выглядеть более чем некрасиво.
Часто бывает, что при публикации записи необходимо указать стороннего пользователя как автора статьи. Конечно, WP позволяет создать аккаунт для этого автора и назначить ему авторство статьи. Но есть ли необходимость создавать аккаунт, если этот автор опубликуется всего лишь 1 раз? А что произойдет, если этот аккаунт удалить? Эта статья будет привязана к другому пользователю, который будет выбран при удалении. Не плодить же кучу 1-разовых аккаунтов. Тут нам приходят на помощь произвольные поля (custom fields). Для того, чтобы назначить авторство статьи стороннему лицу, при публикации создаем произвольное поле pauthor и назначаем ему в виде значения автора, например Вася Пупкин. Если у Васи Пупкина есть сайт, на который можно сослаться, создаем еще одно поле pauthurl и пишем ссылку http://… как значение.
В файлах темы index.php и single.php разместите вот такой код:
Это правило (строки 2, 3, 4 кода) будет выводить сторонних автором простым текстом (либо ссылкой, если укажете), а ваши “штатные” авторы будут выводиться обычной функцией WP the_author_posts_link(); (строка 6 в вышеуказанном коде), если произвольные поля отсутствуют.
Автообновление ядра и плагинов WordPress, впервые представленное в версии 2.7 донельзя облегчило жизнь всем, пользующимся этим движком. Но на некоторых хостингах, в зависимости от настроек, автообновление не работает в автоматическом режиме (вот такая тавтология!) и просит пользователей ввести в предлагаемую вместо обновления форму параметры ФТП – хост, логин, пароль. На одном из хостингов я столкнулся с тем, что данная форма наотрез отказывалась принимать предлагаемые сервер, логин и пароль и сообщала, что “connect failed”. Поиски решения в гугле навели на следующие варианты решения:
1. В форме вместо обычного имени сервера, типа mydomain.ru, попробовать ввести localhost или localhost:21 (это у меня сработало)
2. Чтобы не вводить хост, логин и пароль каждый раз, можно их прописать в файле wp-config.php в таком формате:
Первая строка – это сервер, там нужно ввести имя сервера в зависимости от того, как он у вас работает – по домену или localhost :). Вторая и третья – FTP-логин и пароль соответственно.
Надеюсь, это кому-нибудь поможет.
Это статья – сокращенный и достаточно вольный перевод статьи “Custom Fields Hacks For WordPress”, опубликованной в Smashing Magazine (ссылка на оригинал дана в конце). Перечислены 10 способов интересного применения custom fields (пользовательских полей) в WordPress.
1. Установка дата окончания поста.
Этот прием поможет установить дату окончания публикации поста, если вам нужно отображать запись в течение ограниченного времени.
В теме заменяем цикл вывода на следующий:
< ?php
if (have_posts()) :
while (have_posts()) : the_post(); ?>
$expirationtime = get_post_custom_values('expiration');
if (is_array($expirationtime)) {
$expirestring = implode($expirationtime);
}
$secondsbetween = strtotime($expirestring)-time();
if ( $secondsbetween > 0 ) {
// For example...
the_title();
the_excerpt();
}
endwhile;
endif;
?>
При написании поста создается пользовательское поле с ключом expiration и временем в формате mm/dd/yyyy 00:00:00 в качестве значения. Пост перестанет отображаться после наступления указанной даты и времени.
2. Отображение постов на главной странице.
Этот прием поможет выбрать, как отобразить пост на главной странице – полностью или только анонс. Как и в предыдущем способе, надо заменить стандартный цикл вывода на следующий:
< ?php if (have_posts()) :
while (have_posts()) : the_post();
$customField = get_post_custom_values("full");
if (isset($customField[0])) {
//Custom field is set, display a full post
the_title();
the_content();
} else {
// No custom field set, let's display an excerpt
the_title();
the_excerpt();
endwhile;
endif;
?>
Данный код отображает все посты в виде анонсов. Чтобы отобразить выбранный пост полностью, надо создать поле с ключом full и задать ему любое значение.
3. Отображение музыки и настроения в посте.
У пользователей ЖЖ есть две удобные опции при написании поста, которые пока отсутствуют в WordPress – отображение текущих музыки и настроения. Добавить их в WP достаточно просто – нужно в файле single.php или index.php текущей темы добавить следующий код:
$customField = get_post_custom_values("mood");
if (isset($customField[0])) {
echo "Mood: ".$customField[0];
}
В посте создаем поле с ключом mood и как значение вписываем настроение.
4. Добавление META-описание к постам.
Хоть META-информация и не так уже важна для поисковиков, как раньше, все же не помешает иметь META-описание для ваших записей.
В файл header.php добавьте этот код в любом месте между тэгами <head> и </head>
">
Этот прием использует тэги WordPress для генерации meta-описаний. На страницах категорий, тэгов, архивов и главной используется статическая meta-информация. Отредактируйте строки 3, 7 и 9 в коде для определения ваших собственных значений. Для записей создайте поле Metadescription и впишите значения.
5. Ссылки на внешние ресурсы.
Как создать ссылку в заголовке на внешний ресурс “напрямую”, без ссылки на сам пост (как это бывает на Хабре – прим. перев.)? Для этого есть такой эстетичный способ. Сначала в файл functions.php вставляем следующий код:
Теперь при написании поста нужно создать поле со значением url1 или title_url или url_title и вписать ссылку на внешний ресурс как значение. Заголовок поста при этом станет не ссылкой на сам пост, как обычно, а ссылкой на внешний ресурс (снова вспомним Хабр – прим. перев.). Если значение поля не найдено, заголовок будет традиционно вести на сам пост.
6. Встроенные CSS-стили.
Иногда нужно добавить к записям дополнительные стили CSS. Конечно, всегда можно использовать встроенные (inline), но это иногда не очень удобно. Данный прием поможет легко создавать дополнительные классы CSS и вставлять их в заголовок блога.
В файле header.php в любом месте между тэгами <head> и </head> вставляем код
< ?php if (is_single()) {
$css = get_post_meta($post->ID, 'css', true);
if (!emptyempty($css)) { ?>
При написании записи создаем поле css и вписываем нужный CSS как значение. Вот настолько просто!
7. Переопределение <TITLE>
Тэг title чрезвычайно важен для SEO и привлечения траффика на ваш блог. И, кстати, большинство тем для WP поставляется без оптимизированного тэга title. Сторонние плагины, типа All in One SEO Pack могут помочь решить задачу, но так же этого можно достигнуть с помощью пользовательских полей.
В файле header.php заменяем код в <title> </title> на
При написании поста создаем поле title и вписываем нужное значение.
8. Блокирование поисковых систем от индексации определенных постов.
Вы хотели когда-нибудь запретить поисковику индексировать определенные записи (например, что-то очень личное)? Но при этом разрешить его читать простым читателям. Это достаточно просто с помощью… вы уже поняли чего.
Сначала нужно найти ID поста, который подлежит сокрытию от вездесущих поисковиков. В примере используем ID 17.
В файл header.php добавьте этот код в любом месте между тэгами <head> и </head>
Пользовательское поле noindex и ID поста как значение запретят поисковым системам индексировать контент данного поста.
9. Получить или вывести значение любого поля.
Теперь вы используете множество пользовательских полей. Как насчет того, чтобы автоматически получать все значения? В файл functions.php вставляется вот такой код:
function get_custom_field_value($szKey, $bPrint = false) {
global $post;
$szValue = get_post_meta($post->ID, $szKey, true);
if ( $bPrint == false ) return $szValue; else echo $szValue;
}
Теперь для вызова функции и получения значения полей, используем такой вот код:
< ?php if ( function_exists('get_custom_field_value') ){
get_custom_field_value('featured_image', true);
} ?>
Сначала используется функция PHP function_exists(), чтобы удостовериться что функция get_custom_field_value определена в теме. Первый аргумент функции – название поля (в этом случае featured_image) и второй – получение значения (true) или вызов его для дальнейшего использования (false).
10. Вывод кнопик “Digg This” только при необходимости.
Очень удобная и хорошая идея использовать кнопку “Digg This”, чтобы получать траффик с Digg. Но нужна ли эта кнопка ко всем постам? Вряд ли стоит использовать Digg, например, для объявления изменений на вашем сайте. Нас снова выручат пользовательские поля.
Открываем файл single.php и вставляем этот куда туда, где мы хотим видеть кнопку “Digg This”.
Пользовательское поле digg с любым значением отобразит кнопку “Digg This” (javascript, использованный в коде, покажет кнопку, предоставленную самим Digg). Если значения нет, кнопка не будет показана.
Бонус. Отображение миниатюр (thumbnails) рядом с записями.
Это достаточно известный прием и он успешно используется очень многими. Но некоторые все еще не знают, как красиво показать миниатюры рядом с постами на странице.
1. Создайте изображение по умолчанию в редакторе вроде PhotoShop или Gimp. Размер в приведенном примере 200х200, но конечно, это на ваше усмотрение. Назовите изображение default.gif и загрузите его в папку images в текущей теме.
2. В файле index.php вставьте это код в то место, где вы желаете видеть миниаютюры.
3. При написании создавайте пользовательское поле с ключом post-img и путь к изображению, которое вы хотели бы отобразить как миниатюру, как значение его.
Еще один способ отображать профиль автора на мультиавторском блоге. Но в отличие от предыдущего в данном методе задействовано не редактирование страниц темы, а плагин, который придаст Вашему блогу некоторой “web 2.0-ности”.
Для начала нужно скачать плагин под названием , после чего, как обычно, скопировать его в папку плагинов и активировать.
После этого в файлах текущей темы в место вызова авторов поста вставить вот такой код:
<?php if (function_exists('author_exposed')){author_exposed();} ?>
Теперь при клике на ссылку автора будет выводиться вот такой симпатичный pop-up с отображением информации об авторе из его профайла и ссылкой на его записи.