NodeJS模块和ES6模块系统语法及注意点
社区模块规范:
1.CommonJS规范
规范实现者:
NodeJS 服务端
Browserify 浏览器
2.AMD规范 全称 异步模块定义
规范实现者:
RequireJS 浏览器
3.CMD规范 通用模块定义
规范实现者:
seaJS 服务端和浏览器通用
官方模块规范
1.ESM规范 就是ES6 Module
各浏览器和服务端
目前常用的就是浏览器端的RequireJS、NodeJS、以及ESM
CommonJS语法分析
module.export
关键
1.module.exports实质上是一个对象,最后模块导出的对象就是这个引用指向的对象
module.export.key = value
// eg:
module.export.a = 1;
// 整体管理导出,此时exports与module.exports指向断开,导致exports上的属性被忽略
module.export = {
a:1,
b:1
}
2.exports是一个module.export的助手变量,用于就地导出,两者默认指向同一对象,即module.exports === exports true
// 像比较长的程序,写完所有之后,再去找到需要导出的变量再移到低端的export.module上逐个添加,是相当麻烦,一般在变量下决定是否导出
//eg
let fA = function () {
}
module.exports.fA = fA
let fB = function () {
}
module.exports.fB = fB
// exports 简洁很多
let fA = function () {
}
module.fA = fA
let fB = function () {
}
module.fB = fB
3.在逐个导出时使用exports,而在导出一个对象时,使用module.exports,不建议混用,如果需要,可以作一下处理:
// 在最后导出时将exports对象和module.exports对象合并
exports.a = 1
module.exports = Object.assign({
b : 1
},exports)
require
关键:
1.模块区分,知道即可
let f = require('url')
// 核心模块,第三方模块(npm安装),指定模块名即可
let f = require ('modulename')
// 自定义模块,需指定相对或者绝对路径
let f = require('absolutePATH/relativeAPTH')
2.查找时,没有后缀名的会尝试添加.js、.json、.node,这里可以稍微偷个懒
let f = require('./circle')
// 等同于
let f = require('./circle.js')
ESM语法分析:
export var/function/class
关键:
1.导出值和内部值要有对于关系,即
// error
export 1
// error
let m = 1
export m
// correct
export let m = 1
// correct
let m = 1;
export {m}
直接在声明时导出或者用一个{}包裹导出
2.export default 用于导出一个默认值,使得用户可以不需要知道内部导出变量名称即可使用
PS: 一个模块只能有一个默认导出
export default 等同 export {add as default}
// 不能接变量声明语句
export default let a = 1
普通导出与默认导出使用的区别
// 普通导出的导入使用
export {f}
import {f} from 'fmod'
// 默认导出的导入使用,可以无需知道导出模块的内部变量名,任意重命名
export default f
import c from 'fmod'
3.导出值与模块值是动态绑定的
export let foo = 'bar';
// 500毫秒后,其他模块拿到的foo值会变成bar
setTimeout(() => foo = 'baz', 500);
import用法
关键:
1.导入非默认变量时需要使用{}语法,并且变量要与导出时变量一致
// 普通导出的导入使用
export {f}
import {f} from 'fmod'
2.导入默认变量时,省略{},并且可以重命名导出变量
// 默认导出的导入使用,可以无需知道导出模块的内部变量名,任意重命名
export default f
import c from 'fmod'
3.可以使用*导出整体模块
// circle.js
export let radius = 1
export let area = 2*PI*radius
// main.js
import * as circle from './circle.js'
circle.radius
circle.area
4.可以使用,同时导出默认导出和常规导出
import _,{each, forEach} from 'lodash'
5.多次import同一模块,只会执行一次
6.import可以与require混用,但是其在静态分析阶段执行,也就是会先于require加载,这在要求一定的导入顺序时要注意
export 与 import复合写法
export { foo, bar } from 'my_module';
// 可以简单理解为,但是合并写法等同于没有在当前模块中导入my_module,即无法使用
import { foo, bar } from 'my_module';
export { foo, bar };
ESM加载CommmonJS
关键:
1.CommonJS模块输出对象module.exports将会被Node转换成默认导出
// 导出
export default module.exports
// 导入,类似导入默认
import m from './m'
2.此时CommonJS模块变量遵循其规则,不会动态绑定
module.exports = 123;
setTimeout(() => module.exports = null,500)
//500毫秒后,module.exports仍然是123
3.由于CommonJS模块运行时,才会确定输出的module.exports对象,而ESM在编译时就要确定接口,导入时,不允许解构语法
import {readFile} from 'fs'
解决方案:
//整体导入
import * as express from 'express'
const app = express.default()
//默认导入,更优
import express from 'express'
const app = express()
NodeJS模块和ES6模块系统语法及注意点的更多相关文章
- commonjs模块和es6模块的区别
commonjs模块与es6模块的区别 到目前为止,已经实习了3个月的时间了.最近在面试,在面试题里面有题目涉及到模块循环加载的知识.趁着这个机会,将commonjs模块与es6模块之间一些重要的的区 ...
- commonjs模块和es6模块的区别?
commonjs模块和es6模块最主要的区别:commonjs模块是拷贝,es6模块是引用,但理解这些,先得理解对象复制的问题,在回过头来理解这两模块的区别. 一.基本数据类型的模块 ./a1.js ...
- Es6模块语法笔记
/** * Created by Administrator on 2017/4/15. */ /*---------------------export命令--------------------- ...
- es6 模块和commonjs规范模块的区别
相关代码地址:https://github.com/blank-x/blog-code/tree/main/1-module 引入变量 es6 导入变量只是一个符号链接,是个常量,类似于const 声 ...
- JS模块之AMD, CMD, CommonJS、UMD和ES6模块
CommonJS 传送门 同步加载,适合服务器开发,node实现了commonJS.module.exports和require 判断commonJS环境的方式是(参考jquery源码): if ( ...
- 深入ES6 模块系统
深入ES6 模块系统 本文转载自:众成翻译 译者:neck 链接:http://www.zcfy.cc/article/4436 原文:https://ponyfoo.com/articles/es6 ...
- es6模块 nodejs模块和 typescript模块
es6模块 import和export nodejs模块 require和module.exports typescript模块 module和export
- ES6模块的import和export用法总结
ES6之前以前出现了js模块加载的方案,最主要的是CommonJS和AMD规范.commonjs前者主要应用于服务器,实现同步加载,如nodejs.AMD规范应用于浏览器,如requirejs,为异步 ...
- ES6模块的import和export用法
ES6之前已经出现了js模块加载的方案,最主要的是CommonJS和AMD规范.commonjs主要应用于服务器,实现同步加载,如nodejs.AMD规范应用于浏览器,如requirejs,为异步加载 ...
随机推荐
- 【MySQL】binlog2sql
binlog2sql 1.安装 shell> git clone https://github.com/danfengcao/binlog2sql.git && cd binlo ...
- ROS源更改
ROS源更改 配置你的电脑使其能够安装来自 packages.ros.org 的软件,使用国内或者新加坡的镜像源,这样能够大大提高安装下载速度 sudo sh -c '. /etc/lsb-relea ...
- [完整版]Postgresql 数据库 备份以及恢复的过程
0. 准备工作 linux机器上面 必须安装上pg数据库 然后 需要将 pg的主程序目录 放到环境变量里面去 便于执行命令. 1. 先备份 . 备份目标数据库: pg_dump -h -F c -f ...
- Android 5.0以下系统支持TLS 1.1/1.2协议版本
一.背景 项目中,客户端与服务端之间普遍使用Https协议通信,突然接到测试同事反馈Android5.0以下手机上,App测试服使用出现问题,出现SSL handshake aborted错误信息,但 ...
- .Net工具类--表达式目录树解析DataReader和DataTable
一.概述 在项目中经常会使用SQL去操作数据库,在读取数据的时候返回结果一般是DataReader和DataSet,其中DataaSet里面可以包含多个DataTable. 读取到数据之后,一般情况下 ...
- leetcode不同路径
62. 一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为“Start” ). 机器人每次只能向下或者向右移动一步.机器人试图达到网格的右下角(在下图中标记为“Finish”). 问 ...
- SharpSocket类库功能介绍
SharpSocket是高性能.轻量级.接口清晰.使用简单的C#语言编写的.NET通信类库.支持TCP收发文本和二进制数据,比如图片.音视频.文档等各类数据.SharpSocket封装了很多底层通信细 ...
- 我是如何一步步编码完成万仓网ERP系统的(五)产品库设计 1.产品类别
https://www.cnblogs.com/smh188/p/11533668.html(我是如何一步步编码完成万仓网ERP系统的(一)系统架构) https://www.cnblogs.com/ ...
- Redis之缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级
目录 Redis之缓存雪崩.缓存穿透.缓存预热.缓存更新.缓存降级 1.缓存雪崩 2.缓存穿透 3.缓存预热 4.缓存更新 5.缓存降级 Redis之缓存雪崩.缓存穿透.缓存预热.缓存更新.缓存降级 ...
- windows10风格 springboot vue.js html 跨域 前后分离 activiti 整合项目框架源码
官网:www.fhadmin.org 此项目为Springboot工作流版本 windows 风格,浏览器访问操作使用,非桌面应用程序. 1.代码生成器: [正反双向](单表.主表.明细表.树形表,快 ...