js文件同步和异步的引入问题

news/2024/4/27 18:55:07/文章来源:https://blog.csdn.net/mantou_riji/article/details/137072904

文章目录

  • 同步加载和异步加载
  • JS模块的加载方法
    • CommonJS
    • ES6
    • ES6的`<script>`标签的加载方式

同步加载和异步加载

  • 同步加载:同步加载是指在主线程上按顺序执行代码,当遇到加载资源(例如网络请求、读取文件)时,主线程会停止执行后续的代码,等待资源加载完成后再接着执行后续的代码。这样的方式可能会导致用户体验不佳,因为当资源加载耗时长时,用户需要等待较长时间才能看到后续的处理结果。
  • 异步加载:异步加载则不会阻塞主线程,它会在后台加载资源,同时主线程还会继续执行后续的代码。当资源加载完成后,通常通过回调函数或者Promise(.then方法)来获取资源,并对其进行处理。这样的方式可以避免阻塞主线程,提升用户体验。

异步加载就是多个资源同时加载,同步加载就是同一时刻只加载一个资源。
JavaScript中,由于它的单线程特性,通常推荐使用异步加载的方式来处理网络请求、文件操作等耗时操作。

JS模块的加载方法

CommonJS

使用CommonJS规范require()函数加载模块是同步的,也就是说在加载完模块之前,后续代码不会执行。这在服务器端环境中非常有用,因为模块文件通常都已经在本地,加载很快,而且一般需要在服务器启动时加载所有必要的模块。

ES6

ES6的模块既可以使用同步加载也可以使用异步加载,取决import的使用方式:

  • 同步加载:同步加载是使用import的静态导入方式,结合from使用 :
    静态加载没有返回值,静态加载是一个语句,

    import module from 'module-name';
    

    在module模块加载完成之前是不会执行下面的代码的,所以在模块导入后的所有地方都可以直接使用该模块。

  • 异步加载:异步加载是使用import的动态导入方式,模块作为import的参数使用(可以是路径名也可以是模块名):
    动态加载的返回值是一个Promise对象,所以可以直接使用.then函数编写回调函数

    import('module-name').then((module) => {// 你可以在这里使用模块
    });
    

    也可以使用async/await语法,

    async function loadModule() {try {const module = await import('module-name');// 使用这个模块} catch (error) {// 处理加载错误}
    }
    

ES6的<script>标签的加载方式

  • <script >导入 —— 同步加载
    <script src="">标签并不是使用模块化的导入导出方式,可以使用该标签加载执行JS文件,但是其中所有的变量和函数都会在全局作用域中。
    <script src="">的导入方式是同步导入。当解析到<script src=“”>的时候会暂停解析HTML,去下载javascript文件,等文件下载完成之后再继续解析剩余的HTML文件。

  • <scrtpt type="module">导入 —— 异步加载
    使用这种方式导入的文件是异步导入,使用<scrtpt type="module">导入的时候浏览器会采用严格模式,并且模块会自动地被异步加载

    <script type="module">import {foo} from './foo.js';foo();
    </script>
    

    或者使用src导入文件:

    <script type="module" src="./main.js"></script>
    

    main.js

    import {foo} from './foo.js';
    foo();
    
  • <script src=“”>的异步加载
    可以在<script>标签中添加asyncdefer属性来使文件异步加载。

    • async 属性:这会使得浏览器非阻塞(异步)地下载 JavaScript 文件,但是一旦文件下载完成,浏览器会立刻解析并执行这个文件,这导致了 HTML 的解析可能会被暂时阻塞。多个包含 async 属性的 <script> 标签,它们的执行顺序无法保证,完全由加载完成的时间顺序决定。

    • defer 属性:这也会使得浏览器非阻塞(异步)地下载 JavaScript 文件,但是与 async 不同的是,包含 defer 属性的 <script> 标签会在整个 HTML 文档解析完成之后才开始执行。如果有多个包含 defer 属性的 <script> 标签,它们的执行顺序会按照在 HTML 文件中的出现顺序来执行。

  • <script>标签异步引入的时候如何判断模块加载完成
    使用<script src="">标签的异步引入,不像直接在js模块中的异步引入可以使用回调函数和Promise来编写异步模块加载完成之后的逻辑,但是我们有其他的解决办法:

    • 使用事件监听器

      <script>
      document.querySelector('script[src="script.js"]').addEventListener('load', function() {// script.js文件加载完成之后执行的逻辑代码
      });
      </script>
      <script async src="script.js"></script>
      
    • 使用onload事件监听

      <script type="module" src="./main.js" onload="init()"></script>
      <script>function init() {// main.js 已加载完毕,你可以在这里使用它导出的函数和变量}
      </script>
      
    • 如果被异步加载的文件可以手动编写,可以使用设置全局回调函数的方式:

      <script>
      window.scriptLoaded = function() {//  script.js文件加载完成之后执行的逻辑代码
      };
      </script>
      <script async src="script.js"></script>
      

      然后在 script.js 中的最后一行调用 scriptLoaded 函数:

      // script.js文件的逻辑代码
      window.scriptLoaded();
      
    • 如果是<script type="module">逻辑代码</script>的方式,可以直接使用动态import的特性

      <script type="module">
      import('script.js').then((module) => {//  script.js文件加载完成之后执行的逻辑代码
      });
      </script>
      

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_1026323.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入浅出:探索Hadoop生态系统的核心组件与技术架构

目录 前言 HDFS Yarn Hive HBase Spark及Spark Streaming 书本与课程推荐 关于作者&#xff1a; 推荐理由&#xff1a; 作者直播推荐&#xff1a; 前言 进入大数据阶段就意味着 进入NoSQL阶段&#xff0c;更多的是面向OLAP场景&#xff0c;即数据仓库、BI应用等。 …

TCPView下载安装使用教程(图文教程)超详细

「作者简介」&#xff1a;CSDN top100、阿里云博客专家、华为云享专家、网络安全领域优质创作者 「推荐专栏」&#xff1a;更多干货&#xff0c;请关注专栏《网络安全自学教程》 TCPView是微软提供的一款「查看网络连接」和进程的工具&#xff0c;常用来查看电脑上的TCP/UDP连接…

【Leetcode】2580. 统计将重叠区间合并成组的方案数

文章目录 题目思路代码复杂度分析时间复杂度空间复杂度 结果总结 题目 题目链接&#x1f517; 给你一个二维整数数组 ranges &#xff0c;其中 ranges[i] [starti, endi] 表示 starti 到 endi 之间&#xff08;包括二者&#xff09;的所有整数都包含在第 i 个区间中。 你需要…

MappedByteBuffer VS FileChannel:从内核层面对比两者的性能差异

本文基于 Linux 内核 5.4 版本进行讨论 自上篇文章《从 Linux 内核角度探秘 JDK MappedByteBuffer》 发布之后&#xff0c;很多读者朋友私信我说&#xff0c;文章的信息量太大了&#xff0c;其中很多章节介绍的内容都是大家非常想要了解&#xff0c;并且是频繁被搜索的内容&…

ubuntu 中安装docker

1 资源地址 进入ubuntu官网下载Ubuntu23.04的版本的镜像 2 安装ubuntu 这里选择再Vmware上安装Ubuntu23.04.6 创建一个虚拟机&#xff0c;下一步下一步 注意虚拟机配置网络桥接&#xff0c;CD/DVD选择本地的镜像地址 开启此虚拟机&#xff0c;下一步下一步等待镜像安装。 3…

Git bash获取ssh key

目录 1、获取密钥 2、查看密钥 3、在vs中向GitHub推送代码 4、重新向GitHub推送修改过的代码 1、获取密钥 指令&#xff1a;ssh-keygen -t rsa -C "邮箱地址" 连续按三次回车&#xff0c;直到出现类似以下界面&#xff1a; 2、查看密钥 路径&#xff1a;C:\U…

银行监管报送系统介绍(十一):金融基础数据报送系统

为了全面落实和实现国务院办公厅下发《关于全面推进金融业综合统计工作的意见》中的综合统计工作的总体目标&#xff0c;中国人民银行调查统计司于2020年6月12日下发了《关于建立金融基础数据统计制度的通知&#xff08;试行&#xff09;》。 2020金融基础数据采集报送 报送时…

Kubernetes概念:服务、负载均衡和联网:2. Gateway API

Gateway API 官方文档&#xff1a;https://kubernetes.io/zh-cn/docs/concepts/services-networking/gateway/ Gateway API 通过使用可扩展的、角色导向的、 协议感知的配置机制来提供网络服务。它是一个附加组件&#xff0c; 包含可提供动态基础设施配置和高级流量路由的 API…

9.windows ubuntu 子系统,centrifuge:微生物物种分类。

上次我们用了karken2和bracken进行了物种分类&#xff0c;这次我们使用centrifuge. Centrifuge 是一种用于快速和准确进行微生物分类和物种鉴定的软件。其主要功能包括&#xff1a; 快速分类和物种鉴定: Centrifuge 可以对高通量测序数据&#xff08;如 metagenomic 或 RNA-Se…

[NLP] 初窥000001

NL(natural language)–自然语言 人类的语言–中文&#xff0c;英语&#xff0c;法语 NLP(Natural Language Processing)–自认语言处理 计算机处理人类语言的技术&#xff0c;它包含翻译、智能问答、文本分类、情感分析等常见应用。 CV(Computational Vision) 感知NLP 认知…

【Java程序设计】【C00388】基于(JavaWeb)Springboot的校园竞赛管理系统(有论文)

Springboot的校园竞赛管理系统&#xff08;有论文&#xff09; 项目简介项目获取开发环境项目技术运行截图 博主介绍&#xff1a;java高级开发&#xff0c;从事互联网行业六年&#xff0c;已经做了六年的毕业设计程序开发&#xff0c;开发过上千套毕业设计程序&#xff0c;博客…

2024/3/27打卡更小的数(十四届蓝桥杯)——区间DP

目录 题目 思路 代码 题目 思路 题目说求数组某个区间中的数进行翻转&#xff0c;由于区间选择多&#xff0c;首先想到DP问题。 第一版想到的方法&#xff08;错误的&#xff09;&#xff0c;当进行状态计算的时候&#xff0c;无法判定区间是否翻转后满足要求&#xff0c;…

js改变图片曝光度(高亮度)

方法一&#xff1a; 原理&#xff1a; 使用canvas进行滤镜操作&#xff0c;通过改变图片数据每个像素点的RGB值来提高图片亮度。 缺点 当前项目使用的是svg&#xff0c;而不是canvas 调整出来的效果不是很好&#xff0c;图片不是高亮&#xff0c;而是有些发白 效果 代码 …

阿里云ECS选型推荐配置

本文介绍构建Kubernetes集群时该如何选择ECS类型以及选型的注意事项。 集群规格规划 目前在创建Kubernetes集群时&#xff0c;存在着使用很多小规格ECS的现象&#xff0c;这样做有以下弊端&#xff1a; 网络问题&#xff1a;小规格Worker ECS的网络资源受限。 容量问题&…

验证码/数组元素的复制.java

1&#xff0c;验证码 题目&#xff1a;定义方法实现随机产生一个5位的验证码&#xff0c;前面四位是大写或小写的英文字母&#xff0c;最后一位是数字 分析&#xff1a;定义一个包含所有大小写字母的数组&#xff0c;然后对数组随机抽取4个索引&#xff0c;将索引对应的字符拼…

iperf网络性能测试工具

iperf命令是一个网络性能测试工具&#xff0c;可以测试TCP和UDP带宽质量。同时也可以通过UDP测试报告网丢包率或者发包性能&#xff0c;是一个非常实用的工具 iperf安装&#xff1a; 可以直接通过官网下载对应系统版本进行安装&#xff08;https://iperf.fr/iperf-download.p…

前端框架前置课(1)---AJAX阶段

1. AJAX入门 1.1 AJAX概念和axios使用 1.1.1 什么是AJAX? 1.1.2 怎么用AJAX? 引入axios.js 获取省份列表数据 1.2 认识URL 1.3 URL查询参数 1.4 常用请求方和数据提交 1.5 HTTP协议-报文 1.5.1 HTTP响应状态码 1.5.1.1 状态码&#xff1a;1XX&#xff08;信息&#xff09…

Java微服务分布式分库分表ShardingSphere - ShardingSphere-JDBC

&#x1f339;作者主页&#xff1a;青花锁 &#x1f339;简介&#xff1a;Java领域优质创作者&#x1f3c6;、Java微服务架构公号作者&#x1f604; &#x1f339;简历模板、学习资料、面试题库、技术互助 &#x1f339;文末获取联系方式 &#x1f4dd; 往期热门专栏回顾 专栏…

JetBrains全家桶激活,分享 WebStorm 2024 激活的方案

大家好&#xff0c;欢迎来到金榜探云手&#xff01; WebStorm公司简介 JetBrains 是一家专注于开发工具的软件公司&#xff0c;总部位于捷克。他们以提供强大的集成开发环境&#xff08;IDE&#xff09;而闻名&#xff0c;如 IntelliJ IDEA、PyCharm、和 WebStorm等。这些工具…

固态硬盘数据恢复难度为何大 固态硬盘数据丢失如何恢复 数据恢复软件

随着时代不断的发展&#xff0c;我们办公工作的内容不断增大&#xff0c;固态硬盘已经成为很多人不可缺少的电脑存储设备。固态硬盘与机械硬盘相比较而言&#xff0c;固态硬盘具备读写速度更快、能耗更低、耐用性更好的优点。虽然固态硬盘优点较多&#xff0c;但是固态硬盘也会…