自定义 WordPress 图库 Post 格式
Customizing WordPress Gallery Post Format
我当前的主题支持画廊 Post 格式。 Gallery 格式从图库中获取所有图像并以幻灯片形式显示它们。我希望能够在每张图片的底部添加标题和照片致谢行,因为它会随着信息的变化而变化。
当前的图库格式模板如下所示:
<?php if ( has_post_format( 'gallery' ) ) : ?>
<div class="gallery-post-format">
<?php
$galleries = get_post_gallery_images( $post );
$output = '<ul class="gallery-images">';
foreach ($galleries as $gallery) {
$output .= '<li>' . '<img src="'. $gallery . '">' . '</li>';
}
$output .= '</ul>';
echo $output;
?>
</div>
<?php endif; ?>
我想添加以下代码来显示每张图片的说明文字和照片出处。
<div>
<?php
$photographer_name = get_post_meta(get_post_thumbnail_id(), 'be_photographer_name', true);
$photographer_url = get_post_meta(get_post_thumbnail_id(), 'be_photographer_url', true);
if ( $photographer_name ) : ?>
<div id="tgg_credit_line" class="tgg-photo-credit" align="right">
📷 Image Credit /
<?php if ( $photographer_url ) : ?>
<a href="<?php echo $photographer_url ?>">
<?php endif; ?>
<?php echo $photographer_name ?>
<?php if ( $photographer_url ) : ?>
</a>
<?php endif; ?>
</div>
<?php endif; ?>
</div>
<div id="tgg_image_caption" class="tgg-image-caption" align="left">
<?php echo get_post(get_post_thumbnail_id())->post_excerpt; ?>
</div>
</div>
我该怎么做?
这个怎么样:
<?php if ( has_post_format( 'gallery' ) ) : ?>
<div class="gallery-post-format">
<?php
$gallery = get_post_gallery( $post, false );
$att_ids = wp_parse_id_list( $gallery['ids'] );
$output = '<ul class="gallery-images">';
for ( $i = 0; $i < count( $gallery['src'] ); $i++ ) {
$att_id = $att_ids[ $i ];
$photographer_name = get_post_meta( $att_id, 'be_photographer_name', true );
$photographer_url = get_post_meta( $att_id, 'be_photographer_url', true );
$image = sprintf( '<img src="%s" />',
esc_url( $gallery['src'][ $i ] ) );
$caption = '<div>';
if ( $photographer_name ) {
$caption .= '<div class="tgg-photo-credit" align="right">';
$caption .= '📷 Image Credit /';
if ( $photographer_url ) {
$caption .= sprintf( '<a href="%s">%s</a>',
esc_url( $photographer_url ), esc_html( $photographer_name ) );
} else {
$caption .= esc_html( $photographer_name );
}
$caption .= '</div><!-- .tgg-photo-credit -->';
}
$caption .= '</div>';
$excerpt = get_post_field( 'post_excerpt', $att_id );
if ( $excerpt ) {
$caption .= /* wrapped */
'<div class="tgg-image-caption" align="left">' .
$excerpt .
'</div><!-- .tgg-image-caption -->';
}
$output .= '<li>' . $image . $caption . '</li>';
}
$output .= '</ul><!-- .gallery-images -->';
echo $output;
?>
</div><!-- gallery-post-format -->
<?php endif; ?>
或另一个版本,直接 echo
es 输出而不是将其保存在变量中(即 $output
):
<?php if ( has_post_format( 'gallery' ) ) : ?>
<div class="gallery-post-format">
<?php
$gallery = get_post_gallery( $post, false );
$att_ids = wp_parse_id_list( $gallery['ids'] );
?>
<ul class="gallery-images">
<?php for ( $i = 0; $i < count( $gallery['src'] ); $i++ ) : ?>
<li>
<?php
$att_id = $att_ids[ $i ];
$photographer_name = get_post_meta( $att_id, 'be_photographer_name', true );
$photographer_url = get_post_meta( $att_id, 'be_photographer_url', true );
$excerpt = get_post_field( 'post_excerpt', $att_id );
?>
<img src="<?php echo esc_url( $gallery['src'][ $i ] ); ?>" />
<div>
<?php if ( $photographer_name ) : ?>
<div class="tgg-photo-credit" align="right">
📷 Image Credit /
<?php if ( $photographer_url ) : ?>
<a href="<?php echo esc_url( $photographer_url ); ?>"><?php echo esc_html( $photographer_name ); ?></a>
<?php else : ?>
<?php echo esc_html( $photographer_name ); ?>
<?php endif; // end $photographer_url ?>
</div><!-- .tgg-photo-credit -->
<?php endif; // end $photographer_name ?>
</div>
<?php if ( $excerpt ) : ?>
<div class="tgg-image-caption" align="left">
<?php echo $excerpt; ?>
</div><!-- .tgg-image-caption -->
<?php endif; // end $excerpt ?>
</li>
<?php endfor; // end gallery loop ?>
</ul><!-- .gallery-images -->
</div><!-- .gallery-post-format -->
<?php endif; ?>
我当前的主题支持画廊 Post 格式。 Gallery 格式从图库中获取所有图像并以幻灯片形式显示它们。我希望能够在每张图片的底部添加标题和照片致谢行,因为它会随着信息的变化而变化。
当前的图库格式模板如下所示:
<?php if ( has_post_format( 'gallery' ) ) : ?>
<div class="gallery-post-format">
<?php
$galleries = get_post_gallery_images( $post );
$output = '<ul class="gallery-images">';
foreach ($galleries as $gallery) {
$output .= '<li>' . '<img src="'. $gallery . '">' . '</li>';
}
$output .= '</ul>';
echo $output;
?>
</div>
<?php endif; ?>
我想添加以下代码来显示每张图片的说明文字和照片出处。
<div>
<?php
$photographer_name = get_post_meta(get_post_thumbnail_id(), 'be_photographer_name', true);
$photographer_url = get_post_meta(get_post_thumbnail_id(), 'be_photographer_url', true);
if ( $photographer_name ) : ?>
<div id="tgg_credit_line" class="tgg-photo-credit" align="right">
📷 Image Credit /
<?php if ( $photographer_url ) : ?>
<a href="<?php echo $photographer_url ?>">
<?php endif; ?>
<?php echo $photographer_name ?>
<?php if ( $photographer_url ) : ?>
</a>
<?php endif; ?>
</div>
<?php endif; ?>
</div>
<div id="tgg_image_caption" class="tgg-image-caption" align="left">
<?php echo get_post(get_post_thumbnail_id())->post_excerpt; ?>
</div>
</div>
我该怎么做?
这个怎么样:
<?php if ( has_post_format( 'gallery' ) ) : ?>
<div class="gallery-post-format">
<?php
$gallery = get_post_gallery( $post, false );
$att_ids = wp_parse_id_list( $gallery['ids'] );
$output = '<ul class="gallery-images">';
for ( $i = 0; $i < count( $gallery['src'] ); $i++ ) {
$att_id = $att_ids[ $i ];
$photographer_name = get_post_meta( $att_id, 'be_photographer_name', true );
$photographer_url = get_post_meta( $att_id, 'be_photographer_url', true );
$image = sprintf( '<img src="%s" />',
esc_url( $gallery['src'][ $i ] ) );
$caption = '<div>';
if ( $photographer_name ) {
$caption .= '<div class="tgg-photo-credit" align="right">';
$caption .= '📷 Image Credit /';
if ( $photographer_url ) {
$caption .= sprintf( '<a href="%s">%s</a>',
esc_url( $photographer_url ), esc_html( $photographer_name ) );
} else {
$caption .= esc_html( $photographer_name );
}
$caption .= '</div><!-- .tgg-photo-credit -->';
}
$caption .= '</div>';
$excerpt = get_post_field( 'post_excerpt', $att_id );
if ( $excerpt ) {
$caption .= /* wrapped */
'<div class="tgg-image-caption" align="left">' .
$excerpt .
'</div><!-- .tgg-image-caption -->';
}
$output .= '<li>' . $image . $caption . '</li>';
}
$output .= '</ul><!-- .gallery-images -->';
echo $output;
?>
</div><!-- gallery-post-format -->
<?php endif; ?>
或另一个版本,直接 echo
es 输出而不是将其保存在变量中(即 $output
):
<?php if ( has_post_format( 'gallery' ) ) : ?>
<div class="gallery-post-format">
<?php
$gallery = get_post_gallery( $post, false );
$att_ids = wp_parse_id_list( $gallery['ids'] );
?>
<ul class="gallery-images">
<?php for ( $i = 0; $i < count( $gallery['src'] ); $i++ ) : ?>
<li>
<?php
$att_id = $att_ids[ $i ];
$photographer_name = get_post_meta( $att_id, 'be_photographer_name', true );
$photographer_url = get_post_meta( $att_id, 'be_photographer_url', true );
$excerpt = get_post_field( 'post_excerpt', $att_id );
?>
<img src="<?php echo esc_url( $gallery['src'][ $i ] ); ?>" />
<div>
<?php if ( $photographer_name ) : ?>
<div class="tgg-photo-credit" align="right">
📷 Image Credit /
<?php if ( $photographer_url ) : ?>
<a href="<?php echo esc_url( $photographer_url ); ?>"><?php echo esc_html( $photographer_name ); ?></a>
<?php else : ?>
<?php echo esc_html( $photographer_name ); ?>
<?php endif; // end $photographer_url ?>
</div><!-- .tgg-photo-credit -->
<?php endif; // end $photographer_name ?>
</div>
<?php if ( $excerpt ) : ?>
<div class="tgg-image-caption" align="left">
<?php echo $excerpt; ?>
</div><!-- .tgg-image-caption -->
<?php endif; // end $excerpt ?>
</li>
<?php endfor; // end gallery loop ?>
</ul><!-- .gallery-images -->
</div><!-- .gallery-post-format -->
<?php endif; ?>