关于 WordPress 缓存 Gravatar 头像到本地,提升网站加载速度的文章已经到处都是,但是之前的一些 WordPress 头像缓存解决方案都是只能缓存一个大小的头像,而子凡这里就将一个升级版给大家分享一下,这也是子凡在做 Fanly 主题中用到的一个功能,毕竟在 WordPress 博客中,很多时候我们不仅仅只是使用一种头像大小,如果网站调用了多个尺寸的头像可能调用大头像的时候会不清晰。
改善功能:支持不同大小的头像;支持自动创建缓存目录。
下面子凡就不多说了,把一下代码加入到你主题的 functions.php 中即可:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | //缓存 Gravatar 头像 add_filter('get_avatar', 'fanly_cache_avatar'); function fanly_cache_avatar($avatar) { if(!is_dir('avatar'))//判断是否有缓存目录 mkdir('avatar', 0755, true);//否者创建头像缓存目录 $tmp = strpos($avatar, 'http'); $g = substr($avatar, $tmp, strpos($avatar, "'", $tmp) - $tmp); $tmp = strpos($g, 'avatar/') + 7; $f = substr($g, $tmp, strpos($g, "?", $tmp) - $tmp); $w = home_url(); list($width,$height,$type,$attr) = getimagesize($g);//获取头像参数 $e = ABSPATH .'avatar/'. $f .'-'.$width.'.jpg'; $t = 604800; //设定 7 天, 单位:秒 if ( empty($default) ) $default = 'https://i.leiue.com/avatar.php'; if ( !is_file($e) || (time() - filemtime($e)) > $t ){ //当头像不存在或者文件超过 7 天才更新 copy(htmlspecialchars_decode($g), $e); }else{ $avatar = strtr($avatar, array($g => $w.'/avatar/'.$f.'-'.$width.'.jpg')); } if (filesize($e) < 500) copy($default, $e); return $avatar; } |
在开发的时候,你还可以再这段代码收尾加上一个控制功能,方便开启或者关闭头像缓存功能。
当然在新版的 WordPress 中,get_avatar 函数已经支持 srcset 来适应高清屏,一些不好的代码在高清屏下可能出现问题。开发者们还是按照自己的喜好或许需要来进行合适的开发和适配咯!
好啦!子凡就给大家分享到这里了,欢迎大家支持子凡原创 WordPress 主题:Fanly
更多关于WordPress优化及疑问可以添加QQ群:255308000
除非注明,否则均为泪雪博客原创文章,禁止任何形式转载
留言评论