WordPress 5.5如何实现以及禁用图片的懒加载?
WordPress 5.5 新增了图片的懒加载功能,此功能不是通过前端JS等方式去实现的,而是根据Chrome 76浏览器的新特性支持原生懒加载特性实现的,仅仅只是简单的给图片加上 loading=”lazy” 的属性。
WordPress5.5懒加载的实现方式
WordPress 5.5 给 the_content 接口新增了 wp_filter_content_tags 函数,它主要做三件事情:
根据图片的 ID 给没有 width 和 height 的图片标签加上这两个属性。
根据图片的 ID 给图片标签加上 srcset 属性。
给图片标签加上 loading=”lazy” 属性。
其中第三点就是实现图片懒加载的,具体执行的函数是 wp_img_tag_add_loading_attr,它把前面获取的图片标签,一个个判断一下有没有 width 和 height 属性,如果有的话,就加上 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=”‘%20.%20$image_url%20.%20′”‘ ) ) {
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
2. 分享目的仅供大家学习和交流,请不要用于商业用途!
3. 如果你也有好源码或者教程,可以到用户中心发布投稿,分享有金币奖励和额外收入!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务 请大家谅解!
5. 如有链接无法下载、失效或广告,请联系站长,可领回失去的金币,并额外有奖!
6. 如遇到加密压缩包,默认解压密码为"www.zyfx8.cn",如遇到无法解压的请联系管理员!
本站部分文章、资源来自互联网,版权归原作者及网站所有,如果侵犯了您的权利,请及时联系我站删除。免责声明
资源分享吧 » WordPress 5.5如何实现以及禁用图片的懒加载?
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 织梦模板使用说明
- 你下载的织梦模板并不包括DedeCMS使用授权,根据DedeCMS授权协议,除个人非盈利站点外,均需购买DedeCMS商业使用授权。购买地址: http://www.desdev.cn/service-dedecms.html