最近在做Parallelism主题,由于我把这个主题定位在相册方面,所以特色图片功能至关重要,于是乎,我先通过以下代码给wordpress后台文章编辑器里加入了特色图像支持(添加在主题的functions.php文件中):
add_theme_support( 'post-thumbnails' );
添加之后,在后台的文章编辑器里就会多出一个“特色图片”选项来,如图:
对了,add_theme_support函数可以很方便给主题添加一些功能支持:函数解释如下:
添加缩略图支持还可以这样:
设置缩略图大小,代码如下:
设置了缩略图大小之后,并不是说你输出特色图像的时候就直接输出这个大小,这个代码的功能只是在你设置缩略图的时候将那个图片生成了一个你设定大小的图片。输出特色图像的时候还是要加上大小,不然就会输出原图。
调用特色图片的方式也很简单,上传特色图片后在需要调用的地方插入以下代码:
如果不想简单的使用一个输出缩略图的函数,那就加上一些判断,用户有设置特色图像的时候就输出特色图像,没有设置的时候就调用文章内容中的第一张图像,如果还没有的话,就调用一个默认图片。
ID, array(360, 200), array('alt'=>$post->post_title) ) : get_post_img( 360, 200 );
//has_post_thumbnail判断是否有特色图像,arry(360,200)为特色图像大小
//get_the_post_thumbnail调用图像
//get_post_img是自定义的调用文章内容中图片函数
echo $thumb_img;
?>
将文章内容中的图片取出来原理很简单,用函数get_post_img即可从文章内容中匹配图片,代码如下:
/i', $post->post_content, $matches);
//要返回的代码$matches[1][0]为匹配的第一个图片代码
$first_img = '';
//如果没有图片,返回默认图片的代码
if(empty($matches[1][0])){
$first_img = '';
}
return $first_img;
}
?>
最后在主题的/images 目录下上传一张名为defalt.png 的图片作为默认图片即可。
关于将文章中显示的第一张图设为特色图像的教程我之前也分享过,但方法略有不同,可以参考:http://blog.bcdon.com/2016/12/2550.html
获取wordpress特色图片URL地址的两种方法可参考:http://blog.bcdon.com/2017/03/2732.html