!
也想出现在这里? 联系我们
内容广告块

WordPress 5.5 图片懒加载实现方式以及怎么禁用懒加载

释放双眼,带上耳机,听听看~!

本文遵守署名 4.0 国际 (CC BY 4.0)协议

WordPress 5.5 新增了图片的懒加载功能,此功能不是通过前端JS等方式去实现的,而是根据Chrome 76浏览器的新特性支持原生懒加载特性实现的,仅仅只是简单的给图片加上 loading="lazy" 的属性。

WordPress5.5懒加载的实现方式

WordPress 5.5 给 the_content 接口新增了 wp_filter_content_tags 函数,它主要做三件事情:

  1. 根据图片的 ID 给没有 width height 的图片标签加上这两个属性。
  2. 根据图片的 ID 给图片标签加上 srcset 属性。
  3. 给图片标签加上 loading="lazy" 属性。

其中第三点就是实现图片懒加载的,具体执行的函数是 wp_img_tag_add_loading_attr,它把前面获取的图片标签,一个个判断一下有没有 widthheight 属性,如果有的话,就加上 loading="lazy" 属性。

另外 WordPress 还提供了懒加载相关的两个接口:

  • wp_img_tag_add_loading_attr:loading 属性的值,默认是 lazy 就是懒加载,也可以根据 $img 改成 eager,就是立即加载。
  • wp_lazy_loading_enabled:是否启用懒加载,默认是 true 启用,也可以改成 false,不用。

禁用 WordPress 5.5 图片延迟加载功能

全局禁用

将下面代码添加到当前主题函数模板 functions.php 中即可。

add_filter( 'wp_lazy_loading_enabled', '__return_false' );

只禁用特定标签的图片延迟加载

    add_filter(
    	'wp_lazy_loading_enabled',
    	function( $default, $tag_name, $context ){
    		if ( 'img' === $tag_name && 'the_content' === $context ){
    			return false;
    		}
    		return $default;
    	},
    	10,
    	3
    );

其中:

  • $default:布尔默认值 true
  • $tag_name:要延迟加载的元素的标记名称。
  • $context:指定图像上下文的可选参数。

禁止特色图片延迟加载

    add_filter(
    	'wp_img_tag_add_loading_attr',
    	function( $value, $image, $context ){
    		if ( 'the_content' === $context ){
    			$image_url = wp_get_attachment_image_url( 67, 'medium' );
    			if ( false !== strpos( $image, ' src="' . $image_url . '"' ) ) {
    				return false;
    			}
    		}
    		return $value;
    	},
    	10,
    	3
    );

如果使用 wp_get_attachment_image ,只需将图像的属性值设置为 : loading false

    echo wp_get_attachment_image(
    	67,
    	'medium',
    	false,
    	array( 'loading' => false ),
    )

插件实现

可以通过以下两个插件实现禁用WordPress懒加载:

Disable Lazy Loading

Lazy Loading Feature Plugin

本文由转载小助手发布

给TA打赏
共{{data.count}}人
人已打赏
PHP学习日记技术笔记

解决,宝塔面板添加计划任务提示文件写入失败,请检查是否开启系统加固功能!

2020-10-28 10:06:00

PHP学习日记

如何批量转换WordPress文章分类

2020-10-28 10:06:34

版权声明 本站所发布的一切与破解相关的文章仅限用于学习和研究目的,请在下载后的24个小时之内,从您的电脑中彻底删除。所有资源均来自于网络,不得用于商业或者非法用途,否则一切后果请用户自负。如有问题请及时与我联系,QQ:526733428,或提交工单。
0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
购物车
优惠劵
今日签到
有新私信 私信列表
搜索

Warning: error_log(/www/wwwroot/zyansong.com/wp-content/plugins/spider-analyser/#log/log-0318.txt): failed to open stream: No such file or directory in /www/wwwroot/zyansong.com/wp-content/plugins/spider-analyser/spider.class.php on line 2900