下载帮

您现在的位置是:首页 > CMS教程 > WordPress

WordPress

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

2020-03-29 06:38WordPress

在《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 echo mmimg(get_the_ID()); ?>"
 

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


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

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

文章评论