WordPress博客文章随机添加图片并设为缩略图

在《WordPress文章列表随机显示缩略图》和《WordPress为文章页添加随机图片实现方法》两篇文章中,余斗主要介绍了如何在Wordpress博客文章中添加图片和调用文章列表缩略图片,这里的图片调用都是随机实现,而且有个缺点就是刷新一次图片变一次,而且文章中的图片和缩略图不一致,这样用户体验不好,对seo也很不友好。

余斗今天给出一种完美解决方法。实现文章正文添加图片并且在缩略图处同步调用,并且刷新也不会改变。话不多说,上代码。

将以下代码复制到当前使用的主题文件的functions.php文件中:

//文章判断图片
add_filter('the_content','isimages');
   
//判断文章是否有图片
function isimages($content)
{
    if( !is_page() ){
        global $post;
        $temp_url = "";
        if ( has_post_thumbnail() ) {
        } else {
            $content = $post->post_content;
            $id = $post->ID;
            preg_match_all('/<img.*?(?: |t|r|n)?src=['"]?(.+?)['"]?(?:(?: |t|r|n)+.*?)?>/sim', $content, $strResult, PREG_PATTERN_ORDER);
            $n = count($strResult[1]);
            if($n > 0){
            }else {
            $temp_no = rand(1,20);
            $temp_url = "<center><p><img src='".get_bloginfo('url')."/images/1-150F5".$temp_no.".jpg' alt='".$post->post_title."'></p></center>";
            $content = $temp_url . $content;
            $my_post = array();
                $my_post['ID'] = $id;
                  $my_post['post_content'] = $content;
            wp_update_post( $my_post );
                   
            }
        }
    }
    return $content;
}

文章页single.php的文章内容调用语法不变,仍为:

<?php the_content(); ?>

这样,就能智能的实现如果文章没有图片就随机调用站点根目录下image文件夹中一张图片,函数中我们规定了选取20张随机图片中的一张,我们这些图片命名为1.jpg、2.jpg、.....20.jpg,所以,我们要准备好这些图片并且上传到网站根目录的images文件夹中,如果没有这个文件夹则新建一个即可。这里即使我们刷新文章页这个调用的随机图片也不会改变,实现永久固定为那张图片。

缩略图这里,调用的时候,需要将以下代码复制到当前使用的主题文件的functions.php文件中:

//截取内容中第一张图

add_theme_support( 'post-thumbnails' );
 
function catch_that_image() {
global $post, $posts;
$first_img = '';
ob_start();
ob_end_clean();
$output = preg_match_all('/<img.+src=['"]([^'"]+)['"].*>/i', $post->post_content, $matches);
$first_img = $matches [1] [0];
if(empty($first_img)){ //Defines a default image
$popimg=get_option( 'mao10_popimg');
$first_img = "$popimg";
}
return $first_img;
}
 
function mmimg($postID) {
  $cti = catch_that_image();
  $showimg = $cti;
  has_post_thumbnail();
  if ( has_post_thumbnail() ) {
  $thumbnail_image_url = wp_get_attachment_image_src( get_post_thumbnail_id(), 'thumbnail');
  $shareimg = $thumbnail_image_url[0];
  } else {
  $shareimg = $showimg;
  };
  return $shareimg;
}

在文章列表缩略图处调用时,需指定图片地址为:

src="<?php%20echo%20mmimg(get_the_ID());%20?>"

例如:余斗的缩略图调用代码为:

<img class="wp-post-image" width="261" height="145" alt="<?php the_title(); ?>" src="<?php%20echo%20mmimg(get_the_ID());%20?>"/>

这样,就完美实现了wordpress博客文章随机调用图片并且指定为缩略图,刷新也不会改变。

THE END
分享
二维码
海报
WordPress博客文章随机添加图片并设为缩略图
在《WordPress文章列表随机显示缩略图》和《WordPress为文章页添加随机图片实现方法》两篇文章中,余斗主要介绍了如何在Wordpress博客文章中添加图片和调用文……
<<上一篇
下一篇>>