13518219792

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

Javascript中的CJS、AMD、UMD和ESM是什么?

一开始,Javascript 没有办法导入/导出模块。这是个问题。想象一下,在一个文件中编写您的应用程序 - 这将是一场噩梦!

创新互联公司2013年至今,先为忠县等服务建站,忠县等地企业,进行企业商务咨询服务。为忠县企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

然后,比我聪明得多的人试图为 Javascript 添加模块化。其中一些是CJS、AMD、UMD 和 ESM。您可能听说过其中一些(还有其他方法,但这些是大玩家)。

我将介绍高级信息:语法、目的和基本行为。我的目标是帮助读者在看到它们时认出。

CJS

CJS 是 CommonJS 的缩写。这是它的样子:

 
 
 
 
  1. //importing  
  2. const doSomething = require('./doSomething.js');  
  3.  
  4. //exporting 
  5. module.exports = function doSomething(n) { 
  6.   // do something 

AMD

AMD 代表异步模块定义。这是一个示例代码:

 
 
 
 
  1. define(['dep1', 'dep2'], function (dep1, dep2) { 
  2.     //Define the module value by returning a value. 
  3.     return function () {}; 
  4. }); 

要么

 
 
 
 
  1. // "simplified CommonJS wrapping" https://requirejs.org/docs/whyamd.html 
  2. define(function (require) { 
  3.     var dep1 = require('dep1'), 
  4.         dep2 = require('dep2'); 
  5.     return function () {}; 
  6. }); 

UMD

UMD 代表通用模块定义。这是它的样子(来源):

 
 
 
 
  1. (function (root, factory) { 
  2.     if (typeof define === "function" && define.amd) { 
  3.         define(["jquery", "underscore"], factory); 
  4.     } else if (typeof exports === "object") { 
  5.         module.exports = factory(require("jquery"), require("underscore")); 
  6.     } else { 
  7.         root.Requester = factory(root.$, root._); 
  8.     } 
  9. }(this, function ($, _) { 
  10.     // this is where I defined my module implementation 
  11.  
  12.     var Requester = { // ... }; 
  13.  
  14.     return Requester; 
  15. })); 

ESM

ESM 代表 ES 模块。实现标准模块系统是 Javascript 的建议。相信很多人都看过这个:

 
 
 
 
  1. import React from 'react'; 

其他情况

 
 
 
 
  1. import {foo, bar} from './myLib'; 
  2.  
  3. ... 
  4.  
  5. export default function() { 
  6.   // your Function 
  7. }; 
  8. export const function1() {...}; 
  9. export const function2() {...}; 

可以在 HTML 中调用,只需执行以下操作:

 
 
 
 
  1.  
  2.   import {func1} from 'my-lib'; 
  3.  
  4.   func1(); 
  5.  

这可能无法在所有浏览器中 100% 工作。

概括

感谢阅读。

本文由闻数起舞翻译自Igor Irianto的文章《What Are CJS, AMD, UMD, and ESM in Javascript?》,转载请注明出处,原文链接:

https://irian.to/blogs/what-are-cjs-amd-umd-and-esm-in-javascript/

【责任编辑:赵宁宁 TEL:(010)68476606】


网站栏目:Javascript中的CJS、AMD、UMD和ESM是什么?
文章地址:http://cdbrznjsb.com/article/djcidec.html

其他资讯

让你的专属顾问为你服务