[VueJsDev] 基础知识 - CommonJs VS ES Module
[VueJsDev] 目录列表
https://www.cnblogs.com/pengchenggang/p/17037320.html
CommonJs VS ES Module
::: details 目录
:::
这里的环境是指在 Node.js 下,有两种模块系统规范。简单来说就是导入导出的规范。两种规范语法不同。
CommonJS 是由 Mozilla 的工程师 Kevin Dangoor 于 2009 年 8 月改名的,原项目叫做 ServerJS,是在 2009 年 1 月创建的。
ES Module 简称 ESM,ESM 是 ES6 开发的规范。ES6 于 2015 年 6 月正式发布,ES Module 于 2019 年 5 月 21 日被 Firefox 67+,Safari 11.1+,Chrome 63+支持。这里的 ES = ECMAScript。
| 模块系统规范 | 发布年份 |
|---|---|
| CommonJS | 2009 年 |
| ES Module | 2015 年 |
::: tip
vue 开发用的是 ES Module 规范。
node.js 默认是 CommonJS,如果要修改的话,需要在 package.json 的 type: "module",就是用 ES Module 了。
:::
常见规范有 AMD、CMD、UMD、CommonJS、ES Module
Node.js 开始是用的 CommonJs
Node.js 从 v13.2.0 之后也引入了规范的 ES Modules 机制
Part. 1: CommonJs
CommonJs 官网 https://www.commonjs.org/
这里都是最常用的方法,用多少写多少。
导出用法
// 导出方法1
exports.a = 1
exports.b = 2
exports.c = () => a + b
// 导出方法2
module.exports = {
a,
b,
c,
}
// 方法1 和 方法2 不能同时使用,因为指针会被覆盖
导出原理
// 其实就是外层套了一个函数 两个入参
function (module, exports) {
// 所以你可以对 module.exports 赋值
// 还可以对 exports.属性 赋值
// 原理就是 入参不能被赋值,但是它的属性你可以赋值
}
导入用法
const { a, b, c } = require("./abc.js")
const aaa = require("./abc.js")
Part. 2: ES Module
ES Module 脚本扩展名是 .mjs,如果要改成.js,需要在 package.json 的 type: "module"。
导出
// 导出单个对象
export let abc = "abc"
export const func = () => {}
// 导出默认对象
const abc = { a, b, c }
export default abc
导入
// 静态导入 最常用
import obj from "abc"
import { bcd } from "abc"
import obj from "./abc"
// 动态导入 import() 是 promise
;(async function () {
const { abc } = await import("./yourjs.mjs")
})()
import("./yourjs.mjs").then(res => {
console.info("res.abc", res.abc)
})
Part. 3: CJS 对比 ESM 表
vue.config.js 用的是 CJS,但是 vue 开发里面的代码都是用的 ESM。
|
-
|
CommonJS | ES Module |
|---|---|---|
| 年份 | 2009 年 | 2015 年 |
| 导出单属性 | exports.a = 1; |
export let abc = 'abc'; |
| 导出 Default | module.exports = abc; |
export default abc; |
| 导入-静态 | - | import obj from 'abc'; |
| 导入-动态 | const {a, b, c} = require('./abc.js'); |
import('./yourjs.mjs') promise |
| 默认扩展名 | .js | .mjs |
Code. 4: 获取文件路径
默认是 当前目录 + 文件相对路径,这个默认不对,应该是 文件当前目录 + 文件相对路径。
- CommonJS 代码
const path = require("path")
const resolve = dir => path.join(__dirname, dir)
const path = resolve("aaa/data.json")
- ES Module 代码
import { readFileSync } from "fs"
import { fileURLToPath } from "url"
import { dirname, resolve } from "path"
const __dirname = dirname(fileURLToPath(import.meta.url))
const path = resolve(__dirname, "corpus/data.json")
const data = readFileSync(path, { encoding: "utf-8" }) // 赠送个读取文件函数
[VueJsDev] 基础知识 - CommonJs VS ES Module的更多相关文章
- 彻底掌握 Commonjs 和 Es Module
目录 Commonjs commonjs 实现原理 require 文件加载流程 require 模块引入与处理 require 加载原理 require 避免重复加载 require 避免循环引用 ...
- UMD、CommonJS、ES Module、AMD、CMD模块的写法
AMD异步模块规范 RequireJS就是AMD的一个典型的实现. 以下是一个只依赖与jQuery的模块代码: // foo.js define(['jquery'], function($){ // ...
- JS JavaScript模块化(ES Module/CommonJS/AMD/CMD)
前言 前端开发中,起初只要在script标签中嵌入几十上百行代码就能实现一些基本的交互效果,后来js得到重视,应用也广泛起来了, jQuery,Ajax,Node.Js,MVC,MVVM等的助力也使得 ...
- 深入 CommonJs 与 ES6 Module
目前主流的模块规范 UMD CommonJs es6 module umd 模块(通用模块) (function (global, factory) { typeof exports === 'obj ...
- OpenGL ES 3.0 帧缓冲区对象基础知识
最近在帧缓冲区对象这里卡了一下,不过前面已经了解了相关的OpenGL ES的知识,现在再去了解就感觉轻松多了.现在就进行总结. 基础知识 我们知道,在应用程序调用任何的OpenGL ES命令之前,需要 ...
- elastic search&logstash&kibana 学习历程(二)es基础知识
简介:es的index索引,document文档对象,副本,多节点集群等基础知识 1.通俗的解释: 在Elasticsearch中,文档归属于一种类型(type),而这些类型存在于索引(index)中 ...
- es 模块的基础知识,深度了解
// 一模块的基础知识 /** * export :用于模块输出的出口 * import :文件引入的入口 */ // 1,第一种方式使用export方式输出 var a = 'a'; var b = ...
- ElasticSearch(四):关于es的一些基础知识讲解
上一篇博客更新完之后,我发现一个问题:在我创建索引的时候依旧无法准确的理解每个字段的意义,所以就有了这个. 1. 关于索引 1.1 关于索引的一些基础知识 在创建标准化索引的时候,我们传入的请求体如下 ...
- 【Xamarin开发 Android 系列 4】 Android 基础知识
原文:[Xamarin开发 Android 系列 4] Android 基础知识 什么是Android? Android一词的本义指“机器人”,同时也是Google于2007年11月5日宣布的基于Li ...
- android图形基础知识
Android核心分析(23)-----Andoird GDI之基本原理及其总体框架 2010-06-13 22:49 18223人阅读 评论(18) 收藏 举报 AndroidGDI基本框架 在An ...
随机推荐
- IServiceBehavior, IOperationBehavior,IParameterInspector
1 public class MyOperationBehavior:Attribute, IOperationBehavior 2 { 3 public void AddBindingParamet ...
- C/C++ 数据结构与算法笔记
实现顺序表 #include <stdio.h> #include <stdlib.h> #define MaxSize 10 int Insert_Elem(int Arra ...
- C#9中使用静态匿名函数
匿名函数是很早以前在C#编程语言中引入的.尽管匿名功能有很多好处,但它们并不便宜.避免不必要的分配很重要,这就是为什么在C#9中引入静态匿名函数的原因.在C#9中,lambda或匿名方法可以具有静态修 ...
- 【技能篇】解决vs编译器scanf等函数不安全问题【手把手操作-一分钟解决】
[技能篇]解决Vs编译器scanf等函数不安全问题 文章目录 说在前面 博主给大家的福利 解决方案 解决过程 尾声 说在前面 大家刚开始学习编程的时候,使用vs编译器.使用scanf等函数的时候遇到的 ...
- 4.if语句--《Python编程:从入门到实践》
4.1 检查多个条件 1.使用 and 检查多个条件 2.使用 or 检查多个条件 4.2 检查特定值是否包含在列表中 使用 in 检查特定值是否在列表中 >>> req ...
- 【译】.NET 8 网络改进(一)
原文 | Máňa,Natalia Kondratyeva 翻译 | 郑子铭 随着新的 .NET 版本的发布,发布有关网络空间中新的有趣变化的博客文章已成为一种传统.今年,我们希望引入 HTTP 空间 ...
- 如何用低代码实现批量导出PDF?
前言 事情是这样的,熟悉我们的朋友都知道,我司有一个为广大开发者朋友们提供学习帮助的地方,叫做新手训练营,具体的内容就是会针对初次接触葡萄城产品和技术的用户,通过 2-3 天的集中学习,采用直播授课的 ...
- NC15447 wyh的问题
题目链接 题目 题目描述 我国现在能源消耗非常严重,现在政府有这样一个工作,每天早上都需要把一些路灯关掉,但是他们想让在关闭的过程中所消耗的能源是最少的,负责路灯关闭的工作人员以1m/s的速度进行行走 ...
- windows网络流量监控
NPCap 官网 https://nmap.org/npcap/ 这是抓包必须先安装的工具,具体的原因可以看 https://github.com/buger/goreplay/wiki/Runnin ...
- nginx配置反向代理缓存
说明 最近运维一个网站里面含有不经常变化的小图片,而每次请求都需要调用file接口获取不太合适.所以就想利用nginx的反向代理缓存来减轻服务接口的请求压力. 工作原理 Nginx反向代理缓存,当客户 ...