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+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Java easyExcel实现导入多sheet的Excel

《JavaeasyExcel实现导入多sheet的Excel》这篇文章主要为大家详细介绍了如何使用JavaeasyExcel实现导入多sheet的Excel,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录1.官网2.Excel样式3.代码1.官网easyExcel官网2.Excel样式3.代码

一文深入详解Python的secrets模块

《一文深入详解Python的secrets模块》在构建涉及用户身份认证、权限管理、加密通信等系统时,开发者最不能忽视的一个问题就是“安全性”,Python在3.6版本中引入了专门面向安全用途的secr... 目录引言一、背景与动机:为什么需要 secrets 模块?二、secrets 模块的核心功能1. 基

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

Mac备忘录怎么导出/备份和云同步? Mac备忘录使用技巧

《Mac备忘录怎么导出/备份和云同步?Mac备忘录使用技巧》备忘录作为iOS里简单而又不可或缺的一个系统应用,上手容易,可以满足我们日常生活中各种记录的需求,今天我们就来看看Mac备忘录的导出、... 「备忘录」是 MAC 上的一款常用应用,它可以帮助我们捕捉灵感、记录待办事项或保存重要信息。为了便于在不同

MySQL Workbench工具导出导入数据库方式

《MySQLWorkbench工具导出导入数据库方式》:本文主要介绍MySQLWorkbench工具导出导入数据库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录mysql Workbench工具导出导入数据库第一步 www.chinasem.cn数据库导出第二步

Java如何根据word模板导出数据

《Java如何根据word模板导出数据》这篇文章主要为大家详细介绍了Java如何实现根据word模板导出数据,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... pom.XML文件导入依赖 <dependency> <groupId>cn.afterturn</groupId>

Python logging模块使用示例详解

《Pythonlogging模块使用示例详解》Python的logging模块是一个灵活且强大的日志记录工具,广泛应用于应用程序的调试、运行监控和问题排查,下面给大家介绍Pythonlogging模... 目录一、为什么使用 logging 模块?二、核心组件三、日志级别四、基本使用步骤五、快速配置(bas