您当前的位置:主页 > 教程合集 > WordPress网站首页WordPress

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

发布时间:2015-12-29编辑:余斗阅读:(0)字号:
    在《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博客文章随机调用图片并且指定为缩略图,刷新也不会改变。
关键字词WordPress缩略图随机图片
余斗余斗
  1. 转载请注明:WordPress博客文章随机添加图片并设为缩略图
  2. 版权声明:本站原创文章,由发表在WordPress分类下,于2015-12-29最后更新
Wordpress4.4新版网页Title的设置方法
WordPress博客如何配置七牛云存储
手机扫一扫 随身带着看
鸿运国际手机登录首页