为什么需要灯箱?
很多时候,我们插入文章、页面中的图片因为尺寸或其他原因,图片是不太清晰的,尤其是截图。这样读者在观看的时候,体验会非常差。特别是有些教程中的图片,本来图片中的文字很小,如果图片还不是很清晰,教程的效果就会打折扣。实现图片点击放大功能,方法有很多种,有添加代码的,也有插件的。本着能不用插件就不用插件的原则,尽量还是用代码实现功能。
开工
方法1
在header.php中添加代码
注意:位置要在</header>之前
<link rel="stylesheet" href="https://jsd.onmicrosoft.cn/gh/fancyapps/fancybox@3.5.7/dist/jquery.fancybox.min.css" />
data:image/s3,"s3://crabby-images/95684/95684c233c5fe444d21304448b662de9ed09b24e" alt="纯代码实现WordPress网站灯箱插图 纯代码实现WordPress网站灯箱插图"
在footer.php中添加代码
注意:位置要在</body>之前
<script src="https://jsd.onmicrosoft.cn/gh/fancyapps/fancybox@3.5.7/dist/jquery.fancybox.min.js"></script>
data:image/s3,"s3://crabby-images/47a2b/47a2b9a865701a1ff85b413bb3c6c68228bdfd1f" alt="纯代码实现WordPress网站灯箱插图1 纯代码实现WordPress网站灯箱插图1"
在functions.php中添加代码
位置任意
注:你可能会在其它地方看到类似的代码。但是与他们不同的是,我的代码更他们相比,增加了对webp的兼容性:)
add_filter('the_content', 'fancybox');
function fancybox($content){
$pattern = array("/<img(.*?)src=('|\")([^>]*).(bmp|gif|jpeg|jpg|png|swf|webp)('|\")(.*?)>/i","/<a(.*?)href=('|\")([^>]*).(bmp|gif|jpeg|jpg|png|swf|webp)('|\")(.*?)>(.*?)<\/a>/i");
$replacement = array('<a$1href=$2$3.$4$5 data-fancybox="gallery"><img$1src=$2$3.$4$5$6></a>','<a$1href=$2$3.$4$5 data-fancybox="images"$6>$7</a>');
$content = preg_replace($pattern, $replacement, $content);
return $content;
}
data:image/s3,"s3://crabby-images/8e48e/8e48e21e640b65121df171d4bfb8f6ec775cdef1" alt="纯代码实现WordPress网站灯箱插图2 纯代码实现WordPress网站灯箱插图2"
方法2
首先,我们先随便选择一张图片
data:image/s3,"s3://crabby-images/c8e16/c8e1610da3589988b115c89cd2a64f73132ebf2e" alt="纯代码实现WordPress网站灯箱插图3 纯代码实现WordPress网站灯箱插图3"
如图所示,点击“(-)”,然后点击“媒体文件”
data:image/s3,"s3://crabby-images/5dfda/5dfda04320ac1673c62d12617963d164721b7c12" alt="纯代码实现WordPress网站灯箱插图4 纯代码实现WordPress网站灯箱插图4"
大功告成
IN THE END
Comments 1 条评论
拿走了,我博客没灯箱被骂了好多次?