您是否通过性能测试工具运行WordPress网站,而只是遇到了推迟WordPress中JavaScript解析的指令?

实施此更改可能会对您网站的页面加载时间产生积极影响,尤其是对于移动访问者而言。但是警告可能有点难以理解,这就是为什么我们要确切解释推迟JavaScript解析的含义以及如何在WordPress网站上实施此更改的原因。

这是您将从本文中学到的内容:

厌倦了缓慢的WordPress托管和低于标准的支持?我们在Kinsta做不同的事情。查看我们的托管计划

  • JavaScript的延迟解析意味着什么
  • 如何判断您的站点是否需要推迟JavaScript的解析
  • 延迟JavaScript解析的不同方法
  • 如何推迟WordPress中JavaScript的解析

如果您只想直接跳到本教程,则可以单击上面列表中的最后一个链接。

推迟WordPress中的JavaScript解析是什么意思?

如果您曾经通过Google PageSpeed Insights,GTmetrix或其他页面速度测试工具来运行WordPress网站,则可能会想到建议推迟JavaScript的解析。

但是……这实际上意味着什么?为什么它是重要的性能考虑因素?

基本上,当有人访问您的WordPress网站时,您网站的服务器会将您网站的HTML内容传递给该访问者的浏览器。

然后,访问者的浏览器从顶部开始,然后遍历代码以呈现您的网站。如果从上到下找到任何JavaScript,它将停止呈现页面的其余部分,直到可以获取和解析JavaScript文件为止。

它将针对找到的每个脚本执行此操作,这可能会对您网站的页面加载时间产生负面影响,因为访问者需要在浏览器下载并解析所有JavaScript时凝视空白屏幕。

如果某个脚本对于网站的核心功能不是必需的(至少在初始页面加载时),则您不希望它妨碍加载网站更重要的部分,这就是为什么这些页面速度测试工具总是告诉您推迟JavaScript的解析。

那么推迟JavaScript解析意味着什么?

本质上,您的网站将告诉访问者的浏览器等待下载和/或解析JavaScript,直到网站的主要内容加载完成。到那时,访问者已经可以看到您的页面并与您的页面进行交互,因此下载和解析JavaScript的等待时间不再具有负面影响。

通过加快内容的非常规加载时间,您可以使Google满意,并为访问者创造更好,更快的体验。

如何判断是否需要推迟JavaScript解析

要测试您的WordPress网站是否需要推迟JavaScript的解析,可以通过GTmetrix运行您的网站。

GTmetrix将给您一个评分,并列出需要延迟的特定脚本:

推迟GTmetrix中JavaScript测试的解析

延迟解析JavaScript的不同方法

有几种不同的方法可以推迟JavaScript的解析。首先,您可以将两个属性添加到脚本中:

  1. 异步
  2. 推迟

通过这两个属性,访问者的浏览器无需暂停HTML解析即可下载JavaScript。但是,不同之处在于,尽管异步不会暂停HTML解析以获取脚本(默认行为),但它确实会暂停HTML解析器以在脚本被获取后执行。

使用defer,访问者的浏览器在解析HTML时仍会下载脚本,但是它们将等待解析脚本,直到HTML解析完成为止。

与Web一起成长的这张图很好地解释了差异:

该图说明了异步与延迟

Varvy的Patrick Sexton推荐的另一种选择是,仅在初始页面加载完成后,才使用脚本来调用外部JavaScript文件。这意味着在初始页面加载完成之前,访问者的浏览器将不会下载或执行任何JavaScript。

最后,您将看到的另一种方法是将JavaScript移至页面底部。但是,这种方法不是一个很好的解决方案,因为即使您的页面很快就会显示出来,访问者的浏览器仍会在加载过程中将页面显示为加载状态,直到所有脚本完成为止。这可能会阻止某些访问者与您的页面进行互动,因为他们认为内容未完全加载。

如何推迟WordPress中JavaScript的解析(4种方法)

要推迟WordPress中JavaScript的解析,您可以采取以下三种主要方法:

  • 插件–有一些很棒的免费和高级WordPress插件可以推迟JavaScript解析。我们将向您展示如何使用两个流行的插件。
  • Varvy方法–如果您精通技术,则可以直接编辑网站的代码,并使用Varvy中的代码段。
  • Functions.php文件–您可以在子主题的functions.php文件中添加代码段,以自动延迟脚本。

您可以单击上方直接跳至首选方法,或通读所有技术以找到最适合您的方法。

1.免费的异步JavaScript插件

Async JavaScript是Frank Goossens提供的免费WordPress插件,也是流行的Autoptimize插件背后的同一个家伙。

它为您提供了一种使用异步或延迟来延迟解析JavaScript的简单方法。

首先,您可以从WordPress.org安装并激活免费插件。然后,转到设置→异步JavaScript来配置插件。

在顶部,您可以启用插件的功能,并在异步和延迟之间进行选择。记得:

  • Async在仍然解析HTML的同时下载JavaScript,然后暂停HTML解析以执行JavaScript。
  • Defer在仍然解析HTML的同时下载JavaScript,并等待执行直到HTML解析完成。

如何使用异步JavaScript插件

再往下,您还可以选择如何处理jQuery。许多主题和插件严重依赖jQuery,因此,如果您尝试推迟解析jQuery脚本,则可能会破坏网站的某些核心功能。最安全的方法是排除jQuery,但您可以尝试将其推迟。只要确保彻底测试您的网站即可。

借助WordPress,我们的流量增长了1,187%。我们将向您展示方法。加入20,000多个其他人,他们每周都会收到有关WordPress内部技巧的新闻!立即订阅成功!感谢您的订阅

您将在一周内收到下一期的Kinsta新闻通讯。

订阅Kinsta新闻通讯订阅我同意条款和条件以及隐私政策

再往下看,您还可以手动推迟推迟添加或排除特定脚本,其中包括一个很好的用户友好功能,可让您定位网站上活动的特定主题或插件:

异步JavaScript包含/排除规则

2.使用WP Rocket插件

虽然我们在Kinsta上不允许大多数缓存插件,但在WP Rocket插件中却允许使用,因为它包含一个内置集成,可以与Kinsta的服务器级缓存很好地配合使用。

除了一系列其他性能优化技术之外,WP Rocket还可以帮助您推迟WP Rocket仪表板的“文件优化”选项卡中的JavaScript解析。在“ JavaScript文件”部分中查找“加载JavaScript延迟”选项。

像Async JavaScript插件一样,WP Rocket还可让您排除jQuery以避免网站内容出现问题:

如何使用WP Rocket推迟JavaScript的解析

3.使用Varvy的推荐方法(代码)

之前,我们提到过Varvy的Patrick Sexton建议使用代码段,等待您的网站完成其初始页面加载后,再下载并执行JavaScript。

您可以通过调整Varvy提供的代码片段,然后在结束之前立即将脚本添加到主题中来实现此方法。 "use strict";function wprRemoveCPCSS(){var preload_stylesheets=document.querySelectorAll('link[data-rocket-async="style"][rel="preload"]');if(preload_stylesheets&&0

标签。

这是Varvy的代码:

function downloadJSAtOnload() { var element = document.createElement("script"); element.src = "http://kinsta.com/defer.js"; document.body.appendChild(element); } if (window.addEventListener) window.addEventListener("load", downloadJSAtOnload, false); else if (window.attachEvent) window.attachEvent("onload", downloadJSAtOnload); else window.onload = downloadJSAtOnload;

确保将“ defer.js”替换为您要延迟的JavaScript文件的实际文件名/路径。然后,您可以使用wp_footer挂钩通过子主题的functions.php文件注入代码。

通过这种方法,您可以将Varvy的代码包装成如下形式:

/ **使用Varvy的代码片段推迟对JavaScript的解析* / add_action('wp_footer','my_footer_scripts');函数my_footer_scripts(){?> REPLACE_WITH_VARVY_SCRIPT <?php}

4.通过functions.php文件延迟JavaScript

最后,您还可以通过将以下代码段添加到您的functions.php文件中,将defer属性添加到您的JavaScript文件中而不需要插件:

函数defer_parsing_of_js($ url){if(FALSE === strpos($ url,'.js'))返回$ url; if(strpos($ url,'jquery.js'))返回$ url;返回“ $ url'defer”; } add_filter('clean_url','defer_parsing_of_js',11,1);

本质上,此代码片段告诉WordPress将defer属性添加到除jQuery之外的所有JavaScript文件中。

它既快速又简单,但是却无法像Async JavaScript插件那样为您提供精细的控制。

您是否收到“延迟解析Javascript警告”消息?不用担心…现在用这4种方法修复它! ?⏳单击以发布摘要

延迟WordPress网站上的JavaScript解析是重要的性能考虑因素。

使用上述方法之一推迟WordPress中JavaScript的解析后,我们建议您做两件事:

  1. 对您的网站进行测试,以确保推迟使用某些脚本不会破坏首屏内容的关键。同样,这通常会在jQuery中发生,这就是为什么很多工具可以让您排除jQuery.js的原因。但是,其他脚本也可能发生这种情况。
  2. 再次通过GTmetrix运行您的站点,以确保您的站点延迟尽可能多的脚本(如果排除jQuery,您可能不会获得完美的成绩-但您的成绩应该更好)。

您对如何推迟WordPress中的JavaScript解析有任何疑问吗?在评论中提问!

1股

.essb_links .essb_links_list li a {margin-top:0px; } @media only屏幕和(最小宽度:64em){.container–narrow.pb–60,.knowledgebase .user-content {位置:相对; } .widget-share {位置:绝对;左:-200px;顶部:0px;高度:100%;宽度:200像素;框大小:border-box; } .widget-share-aligner {width:200px; padding-right:62px;框大小:border-box; } .widget-share-inner {padding-bottom:62px; } .knowledgebase .user-content .widget-share-inner {padding-top:0; } .widget-share .amount {display:flex; align-items:居中;证明内容:flex-end;宽度:100%;保证金右:11像素; font-size:14px;字体重量:500;边距:10px的; } .widget-share .amount svg {margin-right:8px;保证金左:10px的; } .essb_links .essb_links_list {flex-direction:column; align-items:flex-end; } .essb_links .essb_links_list li {display:block; margin-bottom:5px!important; } .widget-share__total {margin-bottom:0px!important; } .widget-share__total .heading–small {color:#999999;字体大小:14px的;字体粗细:300; } .essb-total-value {margin-right:4px; }} .essb_links {margin:0px;填充:0像素; } .essb_counter_right {display:none!important; } .essb_links.essb_template_circles-retina。 ,.essb_links.essb_template_circles-retina .essb_link_linkedin a,.essb_links.essb_template_circles-retina .essb_link_facebook a,.essb_links.essb_template_circles-retina .essb_link_twitter a {颜色:#43414e!背景:#f3f3f6!important; } .essb_links.essb_template_circles-retina li a:focus,.essb_links.essb_template_circles-retina li a:hover {border-color:#fff!important;背景:#43414e!重要; } .essb_links.essb_template_circles-retina a {border-color:#f3f3f6!important;背景:#f3f3f6; } .essb_links .essb_icon:之前{font-size:15px!important;顶:8像素;左:9px; } .essb_links .essb_icon {width:32px;高度:32PX; } .essb_links.essb_counter_modern_right .essb_counter_right {背景:#f3f3f6!important; } @media only屏幕和(最大宽度:63.999em){.widget-share-aligner {位置:相对!important; top:0!重要; } .essb_links .essb_links_list li {margin-right:8px!important; }}