技术学习

Typecho获取文章缩略图,文章缩略图

众所周知,Typehco使用的是MARKDOWN语法,优点就是不用在排版上费太多功夫。整理笔记非常方便。(想要居中的时候想哭……)不过这不是今天讨论的重点。

连续制作了几套Typecho模板,百度找了几个获取缩略图都是需要手动在文章里面找一个图片替换为IMG标签

//Markdown内联式图片编写方式
![我是图片描述](https://cdn1.qqzmly.com/usr/uploads/2019/10/2050932897.jpg)

//Markdown脚部式图片编写方式
![请输入图片描述][1]
[1]: https://cdn1.qqzmly.com/usr/uploads/2019/10/2050932897.jpg

//HTML5图片编写方式  (传统方法都要把前面两种改为下面这个
<img src="https://cdn1.qqzmly.com/usr/uploads/2019/10/2050932897.jpg" alt="请输入图片描述">

今天分享的是Typecho获取文章缩略图,随机缩略图(非插件)

上面三种方式随便一种都能够调用出缩略图,如果文章没有图则输出一张随机图。优先级为HTML5图片编写方式>Markdown内联式图片编写方式>Markdown脚部式图片编写方式>随机缩略图

主题functions.php添加以下代码
function img_postthumb($thumbThis) {
    $db = Typecho_Db::get();
    $rs = $db->fetchRow($db->select('table.contents.text')
        ->from('table.contents')
        ->where('table.contents.cid=?', $thumbThis->cid)
        ->order('table.contents.cid', Typecho_Db::SORT_ASC)
        ->limit(1));
    preg_match_all('/\<img.*?src\=\"(.*?)\"[^>]*>/i', $rs['text'], $thumbUrl);  //通过正则式获取图片地址
    preg_match_all('/\!\[.*?\]\((http(s)?:\/\/.*?(jpg|png))/i', $rs['text'], $patternMD);  //通过正则式获取图片地址
    preg_match_all('/\[.*?\]:\s*(http(s)?:\/\/.*?(jpg|png))/i', $rs['text'], $patternMDfoot);  //通过正则式获取图片地址
    if(count($thumbUrl[0])>0){
        return $thumbUrl[1][0];  //当找到一个src地址的时候,输出缩略图
    }else if(count($patternMD[0])>0){
        return $patternMD[1][0];
    }else if(count($patternMDfoot[0])>0){
        return $patternMDfoot[1][0];
    }else{
        //在主题根目录下的 /img 目录下放随机图片 thumb_开头
        //如:thumb_1.jpg
        return $thumbThis->widget('Widget_Options')->themeUrl."/img/thumb_".rand(1,5).".jpg";
    }
}
index.php等文件里调用方式
<?php echo img_postthumb($this); ?>
GouGe
程志辉 前行的路充满未知,不努力尝试,永远都不知道有多精彩。

发表评论

已有 41 条评论
  1. 学习了,感谢

  2. 好好好二哈学习了

  3. 有没有办法判断图片大于200kb输出默认缩略图?

    1. 应该有办法解决,只是我还不会。我看wordpress的做法是在上传图片的时候自动生成小尺寸的图片在储存空间里,这样的好处是用起来很舒服,但一定程度上会消耗一些空间,不过实际运用中真的很香。

  4. 加载有点慢了!可以优化下

    1. 看了一下是图片加载的问题,服务器带宽解决不了。程序暂时只能写到这样。CDN暂时也不考虑,之前被攻击一夜扣100吃不消……(谢谢提议。

      1. 图片可以尝试白嫖jsdeliver

        1. 谢谢分享,暂时还没有时间折腾。以前玩过一阵子自媒体,经过疫情发现,新闻类的自媒体,要么是搬运要么是带有主观性的报道看不得。最近又看到以前的朋友再说微信又改版了,改来改去,平台一家又一家,我觉得呢,内容永远为王。

  5. 商业互吹,NB!

    1. 哇!!!域名不错~刚去你博客发现没有开放评论不能留爪……

      1. 那是个自留地,2333

  6. 发现有好多人的站点都使用的typecho,看来我也得多学习一下,留个后路哈哈

    1. 每个开源CMS都有它的优势啦~我倒觉得重要的是内容

  7. 膜拜新星主题作者

    1. 嘿嘿,菜鸟一枚~

      1. 这个用插件实现复杂么?

        1. 不难,但是能丢到主题里面解决的事情,没必要单独弄个插件啊

  8. 行家一出手,就知有没有!有空定要试试你做的模板。
    小辉同学,近来一些可好?抗疫战争胜利在望了,期待新学期的到来!

    1. 一切安好,在家备考,愿疫情尽快结束,我想武汉了。(话说刚才服务器被打入阿里云黑洞,刚放出来你评论就过来了)

  9. 别的不评价了,你这个代码高亮我挺喜欢的,哈哈!

  10. 话说主题怎么这么好看呢

  11. 连续制作了几套Typecho模板
    这效率,为你点赞

    1. 嘿嘿,专业学的就是这个。