当前位置:首页 > 教程中心 > CMS教程 > wordpress教程

为WordPress主题添加特色图像功能

所属栏目:wordpress教程 时间:2014-04-09 来源:网络 作者:不详 点击:

featured image

wordpress从2.9版开始支持文章特色图像功能,使用wordpress的特色图像功能,会使用网站更加规范,提高页面加载速度,如何让主题支持特色图像功能很简单。

第一步,添加主题对特色图像功能的支持

将下面代码主题functions.php文件中:

// 添加特色图像功能
add_theme_support('post-thumbnails');
set_post_thumbnail_size(130, 100, true); // 图片宽度与高度

其中图片的长宽可以自行修改。

第二步,添加特色图像调用代码

将下面的代码添加到主题模板的适当位置,比如分类归档模板archive.php主循中:

<?php 
if (has_post_thumbnail()) {
     // 显示特色图像
     the_post_thumbnail();
} else {
     // 设置特色图像
     $attachments = get_posts(array(
          'post_type' => 'attachment',
          'post_mime_type'=>'image',
          'posts_per_page' => 0,
          'post_parent' => $post->ID,
          'order'=>'ASC'
     ));
     if ($attachments) {
          foreach ($attachments as $attachment) {
               set_post_thumbnail($post->ID, $attachment->ID);
               break;
          }
          // 显示特色图像
          the_post_thumbnail();
     }
} ?>

代码说明,如果未手动设置特色图像,那么会自动调用第一个图片附件的“缩略图”作为特色图像,并显示它。

注:代码中所使用的WP函数:

可以到官方Codex查看详细使用说明,并根据需要加以修改。

调用显示特色图像还可以使用另一种方法:

如果你认为将特色图像调用代码加到主题模板主循环中看上去会很乱,可以将下面的代码添加到主题functions.php 文件中:

// 特色图像
add_filter('the_content', 'set_featured_image_from_attachment');
function set_featured_image_from_attachment($content) {
     global $post;
     if (has_post_thumbnail()) {
          // 显示特色图像
          $content = the_post_thumbnail() . $content;
     } else {
          // 获取和设置特色图像 
          $attachments = get_children(array(
               'post_parent' => $post->ID,
               'post_status' => 'inherit',
               'post_type' => 'attachment',
               'post_mime_type' => 'image',
               'order' => 'ASC',
               'orderby' => 'menu_order'
          ));
          if ($attachments) {
               foreach ($attachments as $attachment) {
                    set_post_thumbnail($post->ID, $attachment->ID);
                    break;
               }
               // 显示特色图像
               $content = the_post_thumbnail() . $content;
          }
     }
     return $content;
}

这段代码基本原理与上面的相同 ,除了使用get_children过滤the_content(),而不是get_posts()。

请站长喝杯咖啡?

站长一直坚持白天工作、晚上熬夜更新素材,付出了巨大的精力和时间,其中的辛酸难以言述。

坚持免积分、免登录、无任何限制下载!如果本站素材对你有用,不妨考虑请站长喝杯咖啡鼓励一下!

标签:

你应该也喜欢这些吧

共有 0 条评论

给个评价吧

验证码: