Вывод последних записей
Для вывода последних записей можно использовать виджет, а можно воспользоваться вот такой функцией. В ней можно указывать рубрики, формат ввода, количество записей. Сама функция использует кэширование.
Делаем файл main-functions.php. Кидаем в каталог текущего шаблона. Сам код:
<?php
# дополнительные функции
function maxsite_explode($s = '' ) {
$s = trim( str_replace(',', ' ', $s) );
$s = trim( str_replace(';', ' ', $s) );
$s = trim( str_replace(' ', ' ', $s) );
$s = trim( str_replace(' ', ' ', $s) );
$s = trim( str_replace(' ', ' ', $s) );
$s = trim( str_replace(' ', ' ', $s) );
$s = array_unique( explode(' ', trim($s) ) );
$out = array();
foreach ( $s as $val_key => $val_val )
if ( ( (int) $val_val) > 0 )
array_push( $out, $val_val);
return $out;
}
function maxsite_last_post_cat(
$num_cat = '',
$format = '[DATE] [A][TITLE][/A]',
$datef = 'j.m.Y',
$count = 5
)
{
$options = '-' . $num_cat . $format . $datef . $count;
$cache_key = (string) (md5(__FUNCTION__ . serialize($options)));
if ( $output = wp_cache_get($cache_key) ) return print($output);
ob_start();
$count = (int) $count;
echo '<ul class="is_link last_post">';
$arr_num_cat = maxsite_explode($num_cat);
$num_cat = '';
foreach ($arr_num_cat as $num) {
$num = (int) $num;
if ( $num > 0) $num_cat .= $num . ' ';
}
$num_cat = str_replace(' ', ',', trim($num_cat));
global $wp_version, $wpdb;
$ver = (float) $wp_version;
if ($ver < 2.3) { // только для 2.2
if ( $num_cat ) $num_cat = "AND category_id IN($num_cat)";
else $num_cat = '';
if ( $count == 0 ) $count = '';
else $count = 'LIMIT '. $count;
$sortby = 'post_date DESC';
$request = "SELECT DISTINCT ID, post_title, post_date
FROM $wpdb->posts, $wpdb->post2cat
WHERE post_status = 'publish'
AND post_type = 'post'
AND ID = post_id
{$num_cat}
ORDER BY {$sortby} {$count}";
}
else
{ // запрос для 2.3
if ( $num_cat ) $num_cat = "AND tx.term_id IN ($num_cat)";
else $num_cat = '';
if ( $count == 0 ) $count = '';
else $count = 'LIMIT '. $count;
$sortby = 'p.post_date DESC';
$request = "SELECT DISTINCT p.ID, p.post_title, p.post_date
FROM $wpdb->term_taxonomy tx,
$wpdb->term_relationships tr,
$wpdb->posts p
WHERE
tx.taxonomy='category'
{$num_cat}
AND tx.term_taxonomy_id = tr.term_taxonomy_id
AND tr.object_id = p.ID
AND p.post_status = 'publish'
AND p.post_type = 'post'
ORDER BY {$sortby} {$count}";
}
$posts_new = $wpdb->get_results($request);
if ( $posts_new )
foreach ($posts_new as $post_new) {
//[DATE]
$DATE = mysql2date($datef, $post_new->post_date);
$TITLE = $post_new->post_title; // [TITLE]
$A1 = '<a href="'
. get_permalink($post_new->ID)
. '" title="'
. $TITLE
. '">'; //[A]
$A2 = '</a>'; //[/A]
$out = str_replace('[DATE]', $DATE, $format);
$out = str_replace('[TITLE]', $TITLE, $out);
$out = str_replace('[A]', $A1, $out);
$out = str_replace('[/A]', $A2, $out);
echo '<li>' . $out . '</li>';
}
echo '</ul>';
wp_cache_add($cache_key, ob_get_flush());
}
?>
Использование, например в сайдбаре:
<?php
require_once('main-functions.php');
echo '<div class="last_post">';
maxsite_last_post_cat();
echo '</div>';
?>
Описание maxsite_last_post_cat:
- $num_cat = '' - номера рубрик через запятую, пробел или точку с запятой
- $format = '[DATE] [A][TITLE][/A]' - формат вывода
- $datef = 'j.m.Y' - формат даты (стандарт PHP)
- $count = 5 - кол-во записей
Если рубрики не указывать, то берутся все. Функция использует кэширование.
Постоянная ссылка: http://maxsite.org/?p=292
Версия для печати
