首页>技术知识>WordPress wordpress主题开发:wp主题如何在首页调用文章图片
WordPress教程学习网站
2022-06-22
WordPress教程学习网站丨模板定制、网站使用教程、插件推荐、代码优化、wp建站教程、数据文章采集、系统开发、系统优化,功能开发,仿站教程等各类WordPress技术知识,供网友学习了解。

在开发WordPress CMS主题时,我们可能会用到——在WordPress主题的首页调用文章的图片作为首页的图片展示。wordpress主题的文章图片包括:缩略图和文章内容中的图片。所以,wordpress主题在调用文章图片时,我们要先对它进行判断,如果缩略图存在就调用缩略图;如果缩略图不存在,就调用文章内容中的第一张图片;如果缩略图和文章内容第一张图片都不存在,就调用wordpress主题自带的默认图片。


第一步:在wordpress主题的functions.php文件开启缩略图功能

if ( function_exists('add_theme_support') )  add_theme_support('post-thumbnails'); //开启缩略图


第二步:在wordpress主题的functions.php文件中添加获取文章第一张图片的方法:

function catch_first_image() {
global $post; $first_img = '';
ob_start(); //打开输出缓冲
ob_end_clean(); //清空缓冲区 并关闭输出缓冲

//通过正则来匹配文章内容中的图片,把获取到的图片地址放到$matches数组中
$output = preg_match_all('//i', $post->post_content, $matches);
$first_img = $matches [1] [0]; //从数组中获取第一张图片地址
if(empty($first_img)){ //如果没有图片,就启用默认随机图片
$random = mt_rand(1, 10); //随机 1-10 的数字,表示共10个随机图片
$first_img = get_bloginfo ( 'stylesheet_directory' ).'/images/random/'.$random.'.jpg'; //默认图片路径在主题目录下的/images/random/目录里
}
return $first_img; //返回图片地址
};


第三步:在需要调用文章图片的wordpress主题php文件(如首页)中添加如下代码:

query_posts('posts_per_page=4&caller_get_posts=1&orderby=comment_count&cat=2');  //查询指定分类id=2下的文章4篇
while (have_posts()) : the_post();  //循环调用
echo '';
if (has_post_thumbnail()) { //如果缩略图存在,就调用缩略图
the_post_thumbnail( 'thumbnail',array( 'alt' => trim(strip_tags( $post->post_title )), 'class' => 'home-thumb'));
}else { //如果缩略图不存在,就调用functions.php中的catch_first_image()方法获取第一张图或默认图
echo ''.$post->post_title.'';
}
echo '
';
endwhile; //结束while循环

wp_reset_query(); //结束query_posts查询

有关wordpress主题的缩略图调用方法the_post_thumbnail()的使用,可以参阅wordpress CMS主题如何调用文章缩略图片?

 

显示全部内容...