外部脚本按顺序加载失败,是否与 JavaScript 代码顺序有关?

外部脚本按顺序加载失败,是否与 JavaScript 代码顺序有关?

当引入的外部脚本按顺序加载失败时

在编写HTML代码时,如果按顺序引入的外部脚本标签在页面加载时没有按照顺序执行,可能会让人感到困惑。这是否与这些脚本内部JavaScript代码的顺序有关呢?

解析顺序与执行顺序

根据浏览器的脚本解析机制,顺序引入的脚本标签并不会始终按顺序执行。这是因为浏览器会并行下载和执行脚本。如果某个脚本依赖于其他脚本中的功能,则浏览器将在下载和执行依赖脚本后才执行具有依赖关系的脚本。

使用 defer 属性

为了确保脚本按照引入顺序执行,可以为脚本标签添加 defer 属性。具有 defer 属性的脚本将在浏览器完成对文档的解析和渲染后执行,并且会按照它们在文档中的顺序执行。

示例

在下例中,我们为所有脚本标签添加了 defer 属性:

<!--引入js-->
<script src="./js/jquery.js" defer></script>
<script src="./js/isotope.js" defer></script>
<script src="./js/typed.js" defer></script>
<script src="./js/running.js" defer></script>
<script src="./js/scrollreveal.js" defer></script>
<script src="./js/swiper-bundle.min.js" defer></script>
<script src="./js/smooth-scroll.js" defer></script>

这样一来,这些脚本就会按照引入顺序加载和执行,确保相互依赖的脚本能够正确工作。

以上就是外部脚本按顺序加载失败,是否与 JavaScript 代码顺序有关?的详细内容,更多请关注其它相关文章!