ES6规范 模块导出方式:export、export default
nodejs commonjs规范 模块导入方式:require
nodejs commonjs规范 模块导出方式:exports、module.exports
es6
import ... form...替代 require()
//不接收对象 require:require('s.css')//(es5)improt 's.css' //(es6)//接收对象var o = require('s.js')//es(5)import o form s.js //(es6)
对象的写法
导出一个模块对象(es5):module.exports={
add:add, sub:sub}
导出一个模块对象(es6):module.exports={
add, sub}
注意:这种写法属性名和属性值变量是同一个,否则要分开写module.exprots={
addFn:add, sub}
一个对象中方法的写法
//es5module.exports={addFun:function(x,y){ return x+y
}
}//es6module.exports={
addFun(x,y){ return x+y
}
}
导出对象的写法
calc.js中有两个函数:function add(){}
function sub(){}
//写法一
es5写法:
module.exports.add = add
module.exports.sub = sub
使用:
var calc = require('./calc.js')
es6写法:
exprot function add(){}
exprot function sub(){}
//写法二
es5:
module.exports = {add:add,sub:sub}
es6:
exprot default{
add,sub}
//表示取得calc.js中所有暴露出来的对象(es6)import calc from './calc.js'
//只获取到calc.js中的add方法(按需获取)import {add} from './calc.js'
用export 和import 的写法注意点
1、如果模块中是使用 export default {} 方式导出的对象只能通过 import 对象名称 from '模块路径'
不能通过 import {对象名称} from '模块路径'2、如果就想要import {对象名称} from '模块路径'通过这种方式来按需导入对象中的某个属性
那么应该使用 export 跟着要导出的对象或者方法名称 export function add(){} export function substrct(){}
那么就可以使用: import {add,substrct} from '模块路径'
只需要直接使用 add()方法即可
注意这里不能直接使用: import cacl from '模块路径' 这种方式导入,会报错
从版本8.5.0
开始,Node.js
开始支持原生
ES
模块,可以通过命令行选项打开该功能。新功能很大程度上得归功于
Bradley
Farias。
1.演示
这个示例的代码目录结构如下:
esm-demo/
lib.mjs
main.mjs
lib.mjs:
export
function
add(x,
y)
{
return
x
+
y
}
main.mjs:
import
{add}
from
'./lib.mjs'
console.log('Result:
'+add(2,
3))
运行演示:
$
node
--experimental-modules
main.mjs
Result:
5
2.清单:需要注意的事情
ES
模块:
·不能动态导入模块。但是
动态import()
的相关工作正在进行中,应该很快就能提供支持。
·没有元变量,如
__dirname
和
__filename。但是,有一个的类似功能的提案:“import.meta”。看起来可能是这样:
console.log(import.meta.url)
·现在所有模块标识符都是
URL(这部分在
Node.js
是新增的):
·文件
-
带文件扩展名的相对路径:
../util/tools.mjs
·库
-
没有文件扩展名,也没有路径
lodash
·如何更好地使
npm
库在浏览器中也可用(不使用
bundler)仍有待观察。一种可能性是引入
RequireJS
风格的配置数据,将路径映射到实际路径。目前,在浏览器中使用
bare
path
的模块标识符是非法的。
与
CJS
模块的互操作性
你可以导入
CJS
模块,但它们总是只有默认的导出
-
即
module.exports
的值。让
CJS
模块支持命名导出已经在做了,但可能需要一段时间。如果你能帮忙,可以来做。
import
fs1
from
'fs'
console.log(Object.keys(fs1).length)
//
86
import
*
as
fs2
from
'fs'
console.log(Object.keys(fs2))
//
['default']
·
不能在
ES
模块中使用
require()。主要原因是:
· 路径解析工作稍有不同:ESM
不支持
NODE_PATH
和
require.extensions。而且,它的标识符始终是
URL
也会导致一些细微差异。
·
ES
模块始终以异步方式加载,这确保了与
Web
的最大兼容性。这种加载风格并不能通过
require()
混合使用同步加载
CJS
模块。
·
禁止同步模块加载也可以为
Top-level
await
导入
ES
模块保留后路(一个当前正在考虑的功能)。
3.早期版本的
Node.js
上的
ES
模块
如果要在
8.5.0
之前的
Node.js
版本上使用
ES
模块,请参阅
John-David
Dalton
的
@std/esm。
提示:如果不启用任何可解锁的额外功能,将在
Node.js
保持
100%
兼容原生
ES
模块.
FAQ
什么时候可以不带命令行选项使用ES
模块?
目前的计划是在
Node.js
10
LTS
中默认可使用
ES
模块。
进一步阅读
有关
Node.js
和浏览器中
ES
模块的更多信息:
·
“Making
transpiled
ES
modules
more
spec-compliant”
[using
ES
modules
natively
vs.
transpiling
them
via
Babel]
·
“Module
specifiers:
what's
new
with
ES
modules?”
[Why
.mjs?
How
are
module
specifiers
resolved?
Etc.]
·
“Modules”
[in-depth
chapter
on
ES
modules
in
“Exploring
ES6”]
即将到来的
ECMAScript
提案:
·
博客:
“ES
proposal:
import()
–
dynamically
importing
ES
modules”
·
提案:
“import.meta”
总结
以上就是小编给大家带来的在
Node.js
中使用原生
ES
模块方法解析的全部内容,希望对大家有所帮助。如果您有什么问题,可以给我留言。感谢大家对本站的支持。