js模块(module)和导入,导出(import,export)

2024-06-08 22:12

本文主要是介绍js模块(module)和导入,导出(import,export),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

什么是模块(module)

一个模块(module)就是一个文件。一个脚本就是一个模块。就这么简单。

模块可以相互加载,并可以使用特殊的指令 export 和 import 来交换功能,从另一个模块调用一个模块的函数或者变量,常量...,即可以引入并调用其他模块的方法,也可以导出自身的方法给其他模块使用,

import和export 关键字

  • export 关键字标记了可以从当前模块外部访问的变量和函数。
  • import 关键字允许从其他模块导入功能。
// a.js:
export function a(){console.log("a");
}// index.html:<script type="module">
import {a} from "./a.js"a();
</script>

在这样index文件就通过导入使用了a文件的a()方法,这里的 "./a.js" 是a文件所在的相对路径

模块脚本 总是 被延迟的

  • 下载外部模块脚本 <script type="module" src="..."> 不会阻塞 HTML 的处理,它们会与其他资源并行加载。
  • 模块脚本会等到 HTML 文档完全准备就绪(即使它们很小并且比 HTML 加载速度更快),然后才会运行。
  • 保持脚本的相对顺序:在文档中排在前面的脚本先执行。
<script type="module">alert(typeof button); // object:脚本可以“看见”下面的 button// 因为模块是被延迟的(deferred,所以模块脚本会在整个页面加载完成后才运行
</script>相较于下面这个常规脚本:<script>alert(typeof button); // button 为 undefined,脚本看不到下面的元素// 常规脚本会立即运行,常规脚本的运行是在在处理页面的其余部分之前进行的
</script><button id="button">Button</button>

<scprit>的async属性 可以让module直接执行而不用等待html文档就绪

<script async type="module"></script>

对于模块的使用,大部分时候是在框架的构建工具中,比如,webpack工具。

import 和 export

export可以和要导出的部分分开写

// 导出数组
let months = ['Jan', 'Feb', 'Mar','Apr', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];// 导出类
class User {constructor(name) {this.name = name;}
}// 导出 const 声明的变量
const YEAR = 2024;export  {YEAR,User,months} ;

as和default

使用as可以通过指定的名称使用导入的模块,或者导出模块

// say.js
function sayHi(user) {alert(`Hello, ${user}!`);
}function sayBye(user) {alert(`Bye, ${user}!`);
}export {sayHi as Hi, sayBye as Bye};-------------------------------// main.js
import {Hi as hi, Bye as bye} from './say.js';hi('John'); // Hello, John!
bye('John'); // Bye, John!

default只能与export一起使用,表示默认导出,一个文件只能有一个默认导出

命名的导出默认的导出
export class User {...}export default class User {...}
import {User} from ...import User from ...

 有default的导出模块,引用时不能带括号,同时引用的名称可以自定义,(比如上面的默认导出可以写成 import one from ... 这样one就表示User类)

没有default的导出模块,引用时必须带括号,引用的名称不可以自定义

import() 表达式

import(module) 表达式加载模块并返回一个 promise,该 promise resolve 为一个包含其所有导出的模块对象,我们可以在代码中的任意位置调用这个表达式

尽管 import() 看起来像一个函数调用,但它只是一种特殊语法,只是恰好使用了括号,它不是一个函数。

// index.html
<script>async function load() {let say = await import('./say.js');say.hi(); // Hellolet bye = say.default;bye();// bye}
</script>
<button onclick="load()">Click me</button>// say.js
export function hi() {alert(`Hello`);
}
export default function bye() {alert("bye");
}

在HTML中使用import() 不需要使用module类型script标签,可以通过default属性访问到默认导出。

这篇关于js模块(module)和导入,导出(import,export)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1043451

相关文章

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Nginx添加内置模块过程

《Nginx添加内置模块过程》文章指导如何检查并添加Nginx的with-http_gzip_static模块:确认该模块未默认安装后,需下载同版本源码重新编译,备份替换原有二进制文件,最后重启服务验... 目录1、查看Nginx已编辑的模块2、Nginx官网查看内置模块3、停止Nginx服务4、Nginx

Java实现TXT文件导入功能的详细步骤

《Java实现TXT文件导入功能的详细步骤》在实际开发中,很多应用场景需要将用户上传的TXT文件进行解析,并将文件中的数据导入到数据库或其他存储系统中,本文将演示如何用Java实现一个基本的TXT文件... 目录前言1. 项目需求分析2. 示例文件格式3. 实现步骤3.1. 准备数据库(假设使用 mysql

python urllib模块使用操作方法

《pythonurllib模块使用操作方法》Python提供了多个库用于处理URL,常用的有urllib、requests和urlparse(Python3中为urllib.parse),下面是这些... 目录URL 处理库urllib 模块requests 库urlparse 和 urljoin编码和解码