JavaScript 延迟加载的方法( 7种 )

JavaScript脚本的延迟加载(也称为懒加载)是指在网页的主要内容已经加载并显示给用户之后,再加载或执行额外的JavaScript代码。这样做可以加快页面的初始加载速度,改善用户体验,并减少服务器的压力。

在这里插入图片描述

以下是几种常见的延迟加载JavaScript的方法:

  1. defer 属性

    • 使用 <script> 标签的 defer 属性可以让浏览器在解析文档的同时下载脚本文件,但会在整个文档解析完成后再执行这些脚本。
    • 语法:<script src="example.js" defer></script>
  2. async 属性

    • async 属性告诉浏览器立即开始下载脚本,并且在下载完成后尽快执行它,而不需要等待HTML文档解析完成。这适用于与页面内容无关的脚本,因为它不会阻塞DOM构建。
    • 语法:<script src="example.js" async></script>
  3. 动态创建 <script> 元素

    • 通过JavaScript动态地创建 <script> 元素并添加到文档中,可以在特定事件发生时(如窗口加载完成、用户滚动到某个位置等)才加载脚本。
    • 示例代码:
      var script = document.createElement('script');
      script.src = 'example.js';
      document.body.appendChild(script);
      
  4. 使用 Intersection Observer API

    • 对于按需加载的内容(例如,当用户滚动到页面的某一部分时),可以使用 Intersection Observer API 来监听元素是否进入视口,并在该时刻加载相应的脚本。
    • 示例代码:
      let observer = new IntersectionObserver((entries) => {
        entries.forEach(entry => {
          if (entry.isIntersecting) {
            // 加载脚本
            let script = document.createElement('script');
            script.src = 'example.js';
            document.body.appendChild(script);
            observer.unobserve(entry.target); // 取消观察
          }
        });
      });
      observer.observe(document.querySelector('.lazy-load-script'));
      
  5. 模块化和代码分割

    • 在现代JavaScript开发中,可以使用模块化工具(如 Webpack)进行代码分割。根据路由或者组件的需求来加载必要的JavaScript代码,这样可以确保只有需要的代码被加载,提高性能。
  6. preloadprefetch

    • preload 提示浏览器尽早开始加载资源,但并不立即执行;prefetch 则是提示浏览器在空闲时间预取可能会在未来使用的资源。它们都可以帮助优化加载策略,但不是严格意义上的延迟加载。
    • 语法:<link rel="preload" href="example.js" as="script"><link rel="prefetch" href="example.js">
  7. 服务端渲染 (SSR) 和客户端水合作用 (hydration)

    • 对于使用框架如React, Vue, Angular的应用程序,可以通过服务端渲染生成静态HTML,并在客户端进行水合作用(即应用JavaScript行为)。这种方式可以让用户更快看到页面内容,同时保证交互性。

选择哪种方法取决于具体的场景和需求。对于大多数情况,deferasync 是最简单且有效的解决方案。而对于更复杂的场景,可能需要结合多种技术来实现最佳的性能。

在这里插入图片描述

No.大剑师精品GIS教程推荐
0地图渲染基础- 【WebGL 教程】 - 【Canvas 教程】 - 【SVG 教程】
1Openlayers 【入门教程】 - 【源代码+示例 300+】
2Leaflet 【入门教程】 - 【源代码+图文示例 150+】
3MapboxGL【入门教程】 - 【源代码+图文示例150+】
4Cesium 【入门教程】 - 【源代码+综合教程 200+】
5threejs【中文API】 - 【源代码+图文示例200+】
6Shader 编程 【图文示例 100+】
7Geoserver 【配置教程 100+】
8卫星应用开发教程 【配置+应用教程 100+】
9GIS数字孪生与大模型 【应用实战 100+】
10报表与数字大屏 【Echarts 实战示例】 - 【D3 综合教程】 - 【其他大屏】
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

还是大剑师兰特

打赏一杯可口可乐

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值