浏览器支持

现代浏览器原生支持 JavaScript 模块。这包括 Chrome、Firefox、Safari、Edge 和 Opera。但是,Internet Explorer 等较旧的浏览器不支持模块。对于这些,您可能需要使用像 Webpack 这样的捆绑器或像 Babel 这样的转译器。

在 Node.js 中使用模块
要在 Node.js 中使用 ES 模块,可以使用 .mjs 文件扩展名或在 package.json 文件中设置 \\\"type\\\": \\\"module\\\"。

// package.json{ \\\"type\\\": \\\"module\\\"}

导入别名

JavaScript 模块中的别名允许您使用不同的名称导入和导出功能。这对于避免命名冲突或在导入它们的模块的上下文中提供更具描述性的名称很有用。

// math.jsexport function add(a, b) {   return a   b;} export function subtract(a, b) {   return a - b;}

您可以使用别名导入具有不同名称的这些函数:

// main.jsimport { add as sum, subtract as diff } from \\'./math.js\\';console.log(sum(2, 3)); // 5console.log(diff(5, 3)); // 2

将整个模块导入为别名

您可以将整个模块导入为单个别名,这允许您访问命名空间下的所有导出。

// main.jsimport * as math from \\'./math.js\\';console.log(math.add(2, 3)); // 5console.log(math.subtract(5, 3)); // 2

动态导入

您还可以使用 import() 函数动态导入模块,该函数返回一个承诺。这对于代码分割和延迟加载很有用。

// main.jsconst loadModule = async () => {   try {     const module = await import(\\'./math.js\\');     console.log(module.add(2, 3));   } catch (error) {     console.error(\\'loading error:\\', error);   } }; loadModule();

在此示例中,当调用 loadModule 函数时,math.js 模块会动态加载。

CommonJS (CJS)

CommonJS 是一个主要用于 Node.js 的模块系统。它是 ES Modules 标准化之前的默认模块系统,至今仍在许多 Node.js 项目中广泛使用。它使用 require() 导入模块和 module.exports 或导出以从模块导出功能。

在CommonJS中,module.exports和exports都用于从模块导出值。 Exports 本质上是 module.exports 的简写,允许使用其中任何一个。但是,通常建议一致使用 module.exports 以避免潜在的混乱或意外行为。

在此示例中,module.exports 被分配了一个函数,因此 app.js 中的 require 调用返回该函数。

// greet.jsmodule.exports = function(name) {   return `Hello, ${name}!`;};
// app.jsconst greet = require(\\'./greet\\');console.log(greet(\\'Alice\\')); // \\'Hello, Alice!\\'

在此示例中,exports 用于向 module.exports 添加属性。 app.js 中的 require 调用返回一个带有加法和减法函数的对象。

// math.jsexports.add = function(a, b) {   return a   b;};exports.subtract = function(a, b) {   return a - b;};
// app.jsconst math = require(\\'./math\\');console.log(math.add(2, 3)); // 5console.log(math.subtract(5, 2)); // 3

JavaScript 模块提供了许多好处,可以改善代码的组织、可维护性和性能。

结论

在 JavaScript 开发中,ES 模块的引入标志着传统 CommonJS 模块系统的重大转变。 ES 模块提供了一种标准化且有效的方法来管理依赖关系并提高可维护性。导出和导入语法提供了一种清晰简洁的方式来定义和使用模块,从而促进代码库更好的组织和可读性。

","image":"http://www.luping.net/uploads/20240731/172238652866a988605a468.jpg","datePublished":"2024-07-31T08:42:07+08:00","dateModified":"2024-07-31T08:42:07+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 使用 ES 模块增强 JavaScript 代码:导出、导入等

使用 ES 模块增强 JavaScript 代码:导出、导入等

发布于2024-07-31
浏览:443

Enhancing JavaScript Code with ES Modules: Export, Import, and Beyond

JavaScript 模块是组织和重用 JavaScript 代码的一种方式。使用模块可以将代码分解为更小的、可管理的部分,然后可以根据需要在应用程序的其他部分中导入和使用。这种模块化方法有助于维护干净的代码库,使其更易于调试,并增强代码的可重用性。

ES 模块与 CommonJS

JavaScript 生态系统中有不同的模块系统。 ES 模块 (ESM) 是 ECMAScript 规范中的标准,主要在浏览器中使用,并且越来越多地在 Node.js 中得到支持。 CommonJS 是传统上在 Node.js 中使用的另一个模块系统。

ES 模块 (ESM)

ES 模块 (ESM) 是 JavaScript 中的标准化模块系统,在 ECMAScript 2015 (ES6) 中引入。它们通过启用不同文件之间的函数、对象和原语的导入和导出来实现更好的代码组织和可重用性。该模块系统在现代 JavaScript 环境中得到广泛支持,包括浏览器和 Node.js。

导出和导入

export 关键字标记应可从当前模块外部访问的变量和函数,从而允许它们在应用程序的其他部分中重用。 import 关键字允许从其他模块导入这些功能,从而实现模块化编程和代码重用。

命名导出允许从一个模块导出多个项目。每个项目的导入名称必须与导出时的名称相同。

//modules.js
const greet = () => {
   console.log('Hello World');
};
export { greet};

导入命名导出时,需要使用与导出相同的名称。

import { greet } from './module.js';
greet(); // Hello, World!

默认导出允许每个模块进行单个默认导出。该项目可以使用任何名称导入。

//modules.js
const greet = () => {
   console.log('Hello World');
};
export default greet;

导入时默认导出,可以使用任意名称。

import message  from './module.js';
message(); // Hello, World!

在 HTML 中使用模块

在浏览器中使用模块时,您需要将它们包含在 HTML 文件中。您在




   
   
   
   Js:modules



   



浏览器支持

现代浏览器原生支持 JavaScript 模块。这包括 Chrome、Firefox、Safari、Edge 和 Opera。但是,Internet Explorer 等较旧的浏览器不支持模块。对于这些,您可能需要使用像 Webpack 这样的捆绑器或像 Babel 这样的转译器。

在 Node.js 中使用模块
要在 Node.js 中使用 ES 模块,可以使用 .mjs 文件扩展名或在 package.json 文件中设置 "type": "module"。

// package.json
{
 "type": "module"
}

导入别名

JavaScript 模块中的别名允许您使用不同的名称导入和导出功能。这对于避免命名冲突或在导入它们的模块的上下文中提供更具描述性的名称很有用。

// math.js
export function add(a, b) {
   return a   b;
}
 export function subtract(a, b) {
   return a - b;
}

您可以使用别名导入具有不同名称的这些函数:

// main.js
import { add as sum, subtract as diff } from './math.js';


console.log(sum(2, 3)); // 5
console.log(diff(5, 3)); // 2

将整个模块导入为别名

您可以将整个模块导入为单个别名,这允许您访问命名空间下的所有导出。

// main.js
import * as math from './math.js';


console.log(math.add(2, 3)); // 5
console.log(math.subtract(5, 3)); // 2

动态导入

您还可以使用 import() 函数动态导入模块,该函数返回一个承诺。这对于代码分割和延迟加载很有用。

// main.js
const loadModule = async () => {
   try {
     const module = await import('./math.js');
     console.log(module.add(2, 3));
   } catch (error) {
     console.error('loading error:', error);
   }
 };


 loadModule();

在此示例中,当调用 loadModule 函数时,math.js 模块会动态加载。

CommonJS (CJS)

CommonJS 是一个主要用于 Node.js 的模块系统。它是 ES Modules 标准化之前的默认模块系统,至今仍在许多 Node.js 项目中广泛使用。它使用 require() 导入模块和 module.exports 或导出以从模块导出功能。

在CommonJS中,module.exports和exports都用于从模块导出值。 Exports 本质上是 module.exports 的简写,允许使用其中任何一个。但是,通常建议一致使用 module.exports 以避免潜在的混乱或意外行为。

在此示例中,module.exports 被分配了一个函数,因此 app.js 中的 require 调用返回该函数。

// greet.js
module.exports = function(name) {
   return `Hello, ${name}!`;
};
// app.js
const greet = require('./greet');
console.log(greet('Alice')); // 'Hello, Alice!'

在此示例中,exports 用于向 module.exports 添加属性。 app.js 中的 require 调用返回一个带有加法和减法函数的对象。

// math.js
exports.add = function(a, b) {
   return a   b;
};
exports.subtract = function(a, b) {
   return a - b;
};
// app.js
const math = require('./math');
console.log(math.add(2, 3)); // 5
console.log(math.subtract(5, 2)); // 3

JavaScript 模块提供了许多好处,可以改善代码的组织、可维护性和性能。

  • 可重用性
    模块允许您编写可重用的代码段,这些代码段可以在应用程序的不同部分甚至不同的项目中导入和使用。

  • 可维护性
    通过将代码分解为更小的、独立的模块,您可以更有效地管理和维护代码库。这使得更新、重构和调试各个模块变得更加容易,而不会影响整个应用程序。

  • 代码分割
    模块支持代码分割,使您可以在需要时仅加载必要的代码,从而缩短初始加载时间并提高整体性能。

  • 改进测试
    模块化代码更容易测试,因为您可以单独测试各个模块。这使得测试更加可靠和可维护。

  • 摇树
    像 Webpack 和 Rollup 这样的现代模块捆绑器可以执行树摇动,这是一种从最终捆绑中删除未使用的代码的技术,从而产生更小、更高效的代码。

结论

在 JavaScript 开发中,ES 模块的引入标志着传统 CommonJS 模块系统的重大转变。 ES 模块提供了一种标准化且有效的方法来管理依赖关系并提高可维护性。导出和导入语法提供了一种清晰简洁的方式来定义和使用模块,从而促进代码库更好的组织和可读性。

版本声明 本文转载于:https://dev.to/kda/enhancing-javascript-code-with-es-modules-export-import-and-beyond-1d5?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    将我的加密库从mcrypt升级到openssl 问题:是否可以将我的加密库从McRypt升级到OpenSSL?如果是这样,如何?答案:是的,可以将您的Encryption库从McRypt升级到OpenSSL。可以使用openssl。附加说明: [openssl_decrypt()函数要求iv参...
    编程 发布于2025-07-16
  • Java数组中元素位置查找技巧
    Java数组中元素位置查找技巧
    在Java数组中检索元素的位置 利用Java的反射API将数组转换为列表中,允许您使用indexof方法。 (primitives)(链接到Mishax的解决方案) 用于排序阵列的数组此方法此方法返回元素的索引,如果发现了元素的索引,或一个负值,指示应放置元素的插入点。
    编程 发布于2025-07-16
  • Python中嵌套函数与闭包的区别是什么
    Python中嵌套函数与闭包的区别是什么
    嵌套函数与python 在python中的嵌套函数不被考虑闭合,因为它们不符合以下要求:不访问局部范围scliables to incling scliables在封装范围外执行范围的局部范围。 make_printer(msg): DEF打印机(): 打印(味精) ...
    编程 发布于2025-07-16
  • 左连接为何在右表WHERE子句过滤时像内连接?
    左连接为何在右表WHERE子句过滤时像内连接?
    左JOIN CONUNDRUM:WITCHING小时在数据库Wizard的领域中变成内在的加入很有趣,当将c.foobar条件放置在上面的Where子句中时,据说左联接似乎会转换为内部连接。仅当满足A.Foo和C.Foobar标准时,才会返回结果。为什么要变形?关键在于其中的子句。当左联接的右侧值...
    编程 发布于2025-07-16
  • 在GO中构造SQL查询时,如何安全地加入文本和值?
    在GO中构造SQL查询时,如何安全地加入文本和值?
    在go中构造文本sql查询时,在go sql queries 中,在使用conting and contement和contement consem per时,尤其是在使用integer per当per当per时,per per per当per. 在GO中实现这一目标的惯用方法是使用fmt.spr...
    编程 发布于2025-07-16
  • 如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    如何从PHP中的Unicode字符串中有效地产生对URL友好的sl。
    为有效的slug生成首先,该函数用指定的分隔符替换所有非字母或数字字符。此步骤可确保slug遵守URL惯例。随后,它采用ICONV函数将文本简化为us-ascii兼容格式,从而允许更广泛的字符集合兼容性。接下来,该函数使用正则表达式删除了不需要的字符,例如特殊字符和空格。此步骤可确保slug仅包含...
    编程 发布于2025-07-16
  • `console.log`显示修改后对象值异常的原因
    `console.log`显示修改后对象值异常的原因
    foo = [{id:1},{id:2},{id:3},{id:4},{id:id:5},],]; console.log('foo1',foo,foo.length); foo.splice(2,1); console.log('foo2', foo, foo....
    编程 发布于2025-07-16
  • \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    答案: 在大多数现代编译器中,while(1)和(1)和(;;)之间没有性能差异。编译器: perl: 1 输入 - > 2 2 NextState(Main 2 -E:1)V-> 3 9 Leaveloop VK/2-> A 3 toterloop(next-> 8 last-> 9 ...
    编程 发布于2025-07-16
  • Go语言如何动态发现导出包类型?
    Go语言如何动态发现导出包类型?
    与反射软件包中的有限类型的发现能力相反,本文探讨了在运行时发现所有包装类型(尤其是struntime go import( “ FMT” “去/进口商” ) func main(){ pkg,err:= incorter.default()。导入(“ time”) ...
    编程 发布于2025-07-16
  • 如何解决AppEngine中“无法猜测文件类型,使用application/octet-stream...”错误?
    如何解决AppEngine中“无法猜测文件类型,使用application/octet-stream...”错误?
    appEngine静态文件mime type override ,静态文件处理程序有时可以覆盖正确的mime类型,在错误消息中导致错误消息:“无法猜测mimeType for for file for file for [File]。 application/application/octet...
    编程 发布于2025-07-16
  • 如何使用替换指令在GO MOD中解析模块路径差异?
    如何使用替换指令在GO MOD中解析模块路径差异?
    在使用GO MOD时,在GO MOD 中克服模块路径差异时,可能会遇到冲突,其中可能会遇到一个冲突,其中3派对软件包将另一个带有导入套件的path package the Imptioned package the Imptioned package the Imported tocted pac...
    编程 发布于2025-07-16
  • 如何使用“ JSON”软件包解析JSON阵列?
    如何使用“ JSON”软件包解析JSON阵列?
    parsing JSON与JSON软件包 QUALDALS:考虑以下go代码:字符串 } func main(){ datajson:=`[“ 1”,“ 2”,“ 3”]`` arr:= jsontype {} 摘要:= = json.unmarshal([] byte(...
    编程 发布于2025-07-16
  • Android如何向PHP服务器发送POST数据?
    Android如何向PHP服务器发送POST数据?
    在android apache httpclient(已弃用) httpclient httpclient = new defaulthttpclient(); httppost httppost = new httppost(“ http://www.yoursite.com/script.p...
    编程 发布于2025-07-16
  • PHP阵列键值异常:了解07和08的好奇情况
    PHP阵列键值异常:了解07和08的好奇情况
    PHP数组键值问题,使用07&08 在给定数月的数组中,键值07和08呈现令人困惑的行为时,就会出现一个不寻常的问题。运行print_r($月份)返回意外结果:键“ 07”丢失,而键“ 08”分配给了9月的值。此问题源于PHP对领先零的解释。当一个数字带有0(例如07或08)的前缀时,PHP将...
    编程 发布于2025-07-16
  • PHP与C++函数重载处理的区别
    PHP与C++函数重载处理的区别
    作为经验丰富的C开发人员脱离谜题,您可能会遇到功能超载的概念。这个概念虽然在C中普遍,但在PHP中构成了独特的挑战。让我们深入研究PHP功能过载的复杂性,并探索其提供的可能性。在PHP中理解php的方法在PHP中,函数超载的概念(如C等语言)不存在。函数签名仅由其名称定义,而与他们的参数列表无关。...
    编程 发布于2025-07-16

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3