Описание
Возвращает картинку прикрепленного к посту файла (вложения).
Картинка возвращается в виде html кода (<img>). Если вложение не удалось найти, то будет возвращена пустая строка.
Если вложение является картинкой, то для нее будет возвращен код, соответствующий указанному размеру (см. параметр $size).
Для прикрепленных файлов типа отличного от картинок (.zip, .xls, .flv) будет возвращена соответствующая этому типу иконка (автоматически определяется WordPress). По умолчанию такая иконка не выводится, чтобы она выводилась нужно выставить 3-й параметр ($icon) в true.
wp_get_attachment_image() работает на базе wp_get_attachment_image_src().
Использование
<?php echo wp_get_attachment_image( $attachment_id, $size, $icon ); ?>
Параметры
- $attachment_id (число) (обязательный)
- ID вложения, картинку которого нужно получить.
По умолчанию: нет - $size (строка/массив)
- Размер картинки. Можно указать в виде строки (thumbnail, medium, large или full) или в виде массива из 2-х элементов, определяющих размеры сторон выводимой картинки (array(32,32)). Указание размеров не влияет на размеры выводимых иконок для файлов, они всегда выводятся в оригинальном размере (32х32).
Так же указание размеров через массив не уменьшает картинку физически, она уменьшается только визуально из наиболее подходящего готового варианта в хранилище WordPress (uploads).
Вместо использования массива, логично зарегистрировать новый размер картинок (add_image_size()) и использовать его наряду с уже установленными (thumbnail, medium, large или full). Такой подход более эффективен, так как нет нужды постоянно проверять какой размер из имеющихся подходил лучше.
По умолчанию: "thumbnail" - $icon (логический)
- Использовать ли медиа иконки, для представления вложения. По умолчанию, для вложений типа файл (не картинок), иконка выводится не будет, если нужно выводить иконки для таких типов вложений выставите этот параметр в true.
По умолчанию: false
Примеры
1. Выведем картинку среднего размера прикрепленного файла-картинки 651:
<?php echo wp_get_attachment_image( 651, 'medium'); ?>
2. Выведем картинку указанного размера 20х20 пикселей, для вложений типа "картинка" и соответствующую иконку для остальных типов вложений (3-й параметр):
<?php echo wp_get_attachment_image( $post->ID, array(20,20), true); ?>
$post->ID — динамическая передача ID внутри цикла. Создать такой цикл можно, использовав функцию get_posts() (get_posts('post_type=attachment')).
wp_get_attachment_image()
из файла: /wp-includes/media.php WP 3.3.2function wp_get_attachment_image($attachment_id, $size = 'thumbnail', $icon = false, $attr = '') {
$html = '';
$image = wp_get_attachment_image_src($attachment_id, $size, $icon);
if ( $image ) {
list($src, $width, $height) = $image;
$hwstring = image_hwstring($width, $height);
if ( is_array($size) )
$size = join('x', $size);
$attachment =& get_post($attachment_id);
$default_attr = array(
'src' => $src,
'class' => "attachment-$size",
'alt' => trim(strip_tags( get_post_meta($attachment_id, '_wp_attachment_image_alt', true) )), // Use Alt field first
'title' => trim(strip_tags( $attachment->post_title )),
);
if ( empty($default_attr['alt']) )
$default_attr['alt'] = trim(strip_tags( $attachment->post_excerpt )); // If not, Use the Caption
if ( empty($default_attr['alt']) )
$default_attr['alt'] = trim(strip_tags( $attachment->post_title )); // Finally, use the title
$attr = wp_parse_args($attr, $default_attr);
$attr = apply_filters( 'wp_get_attachment_image_attributes', $attr, $attachment );
$attr = array_map( 'esc_attr', $attr );
$html = rtrim("<img $hwstring");
foreach ( $attr as $name => $value ) {
$html .= " $name=" . '"' . $value . '"';
}
$html .= ' />';
}
return $html;
}Ещё из раздела
Смотрите также: Функции WordPress и Теги Шаблона.
На протяжении долгого периода времени наша бригада выполняет: ремонт квартир в Жуковском (Московской обл) и в других населённых пунктах.